The subject and patch are pretty self-explanatory. Ran into this while trying to do pointer arithmetic with these macros.

--xsdg
>From 0ba4f676e3de80233b7ab184b11e527b61ab6158 Mon Sep 17 00:00:00 2001
From: Omari Stephens <x...@xsdg.org>
Date: Mon, 24 Jan 2011 18:49:08 +0000
Subject: [PATCH] Add missing parens around macro arguments

---
 libgimpwidgets/gimpcairo-utils.h |   32 ++++++++++++++++----------------
 1 files changed, 16 insertions(+), 16 deletions(-)

diff --git a/libgimpwidgets/gimpcairo-utils.h b/libgimpwidgets/gimpcairo-utils.h
index 6d614a0..b538c2d 100644
--- a/libgimpwidgets/gimpcairo-utils.h
+++ b/libgimpwidgets/gimpcairo-utils.h
@@ -105,10 +105,10 @@ cairo_surface_t * gimp_cairo_surface_create_from_pixbuf (GdkPixbuf     *pixbuf);
     const guint tr = (a) * (r) + 0x80;             \
     const guint tg = (a) * (g) + 0x80;             \
     const guint tb = (a) * (b) + 0x80;             \
-    d[0] = (((tb) >> 8) + (tb)) >> 8;              \
-    d[1] = (((tg) >> 8) + (tg)) >> 8;              \
-    d[2] = (((tr) >> 8) + (tr)) >> 8;              \
-    d[3] = (a);                                    \
+    (d)[0] = (((tb) >> 8) + (tb)) >> 8;            \
+    (d)[1] = (((tg) >> 8) + (tg)) >> 8;            \
+    (d)[2] = (((tr) >> 8) + (tr)) >> 8;            \
+    (d)[3] = (a);                                  \
   } G_STMT_END
 #else
 #define GIMP_CAIRO_ARGB32_SET_PIXEL(d, r, g, b, a) \
@@ -116,10 +116,10 @@ cairo_surface_t * gimp_cairo_surface_create_from_pixbuf (GdkPixbuf     *pixbuf);
     const guint tr = (a) * (r) + 0x80;             \
     const guint tg = (a) * (g) + 0x80;             \
     const guint tb = (a) * (b) + 0x80;             \
-    d[0] = (a);                                    \
-    d[1] = (((tr) >> 8) + (tr)) >> 8;              \
-    d[2] = (((tg) >> 8) + (tg)) >> 8;              \
-    d[3] = (((tb) >> 8) + (tb)) >> 8;              \
+    (d)[0] = (a);                                  \
+    (d)[1] = (((tr) >> 8) + (tr)) >> 8;            \
+    (d)[2] = (((tg) >> 8) + (tg)) >> 8;            \
+    (d)[3] = (((tb) >> 8) + (tb)) >> 8;            \
   } G_STMT_END
 #endif
 
@@ -138,10 +138,10 @@ cairo_surface_t * gimp_cairo_surface_create_from_pixbuf (GdkPixbuf     *pixbuf);
 #if G_BYTE_ORDER == G_LITTLE_ENDIAN
 #define GIMP_CAIRO_ARGB32_GET_PIXEL(s, r, g, b, a) \
   G_STMT_START {                                   \
-    const guint tb = s[0];                         \
-    const guint tg = s[1];                         \
-    const guint tr = s[2];                         \
-    const guint ta = s[3];                         \
+    const guint tb = (s)[0];                       \
+    const guint tg = (s)[1];                       \
+    const guint tr = (s)[2];                       \
+    const guint ta = (s)[3];                       \
     (r) = (tr << 8) / (ta + 1);                    \
     (g) = (tg << 8) / (ta + 1);                    \
     (b) = (tb << 8) / (ta + 1);                    \
@@ -150,10 +150,10 @@ cairo_surface_t * gimp_cairo_surface_create_from_pixbuf (GdkPixbuf     *pixbuf);
 #else
 #define GIMP_CAIRO_ARGB32_GET_PIXEL(s, r, g, b, a) \
   G_STMT_START {                                   \
-    const guint ta = s[0];                         \
-    const guint tr = s[1];                         \
-    const guint tg = s[2];                         \
-    const guint tb = s[3];                         \
+    const guint ta = (s)[0];                       \
+    const guint tr = (s)[1];                       \
+    const guint tg = (s)[2];                       \
+    const guint tb = (s)[3];                       \
     (r) = (tr << 8) / (ta + 1);                    \
     (g) = (tg << 8) / (ta + 1);                    \
     (b) = (tb << 8) / (ta + 1);                    \
-- 
1.7.2.3

_______________________________________________
Gimp-developer mailing list
Gimp-developer@lists.XCF.Berkeley.EDU
https://lists.XCF.Berkeley.EDU/mailman/listinfo/gimp-developer

Reply via email to