[cogl/cogl.windows.fixes: 3/4] cogl/cogl-bitmask.h: Use size_t instead of unsigned long
- From: Chun-wei Fan <fanchunwei src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [cogl/cogl.windows.fixes: 3/4] cogl/cogl-bitmask.h: Use size_t instead of unsigned long
- Date: Wed, 13 Feb 2019 10:06:13 +0000 (UTC)
commit c9e69eb2b186fc1e4d463af91b7ec45d78f7b017
Author: Chun-wei Fan <fanchunwei src gnome org>
Date: Tue Feb 12 00:24:07 2019 +0800
cogl/cogl-bitmask.h: Use size_t instead of unsigned long
Using unsigned long is not safe as sizeof(long) is not necessary
sizeof(void*) on some platforms, such as Windows on Visual Studio. To
avoid this, use size_t instead of unsized long, and use the correct
unsigned suffix accordingly.
cogl/cogl-bitmask.h | 22 ++++++++++++++--------
1 file changed, 14 insertions(+), 8 deletions(-)
---
diff --git a/cogl/cogl-bitmask.h b/cogl/cogl-bitmask.h
index e0db3df2..a9de09aa 100644
--- a/cogl/cogl-bitmask.h
+++ b/cogl/cogl-bitmask.h
@@ -62,19 +62,25 @@ COGL_BEGIN_DECLS
typedef struct _CoglBitmaskImaginaryType *CoglBitmask;
/* These are internal helper macros */
+#if defined (G_OS_WIN32) && (GLIB_SIZEOF_VOID_P == 8)
+# define COGL_PTR_APPEND_SUFFIX(x) x##ULL
+#else
+# define COGL_PTR_APPEND_SUFFIX(x) x##UL
+#endif
+
#define _cogl_bitmask_to_number(bitmask) \
- ((unsigned long) (*bitmask))
+ ((size_t) (*bitmask))
#define _cogl_bitmask_to_bits(bitmask) \
- (_cogl_bitmask_to_number (bitmask) >> 1UL)
+ (_cogl_bitmask_to_number (bitmask) >> COGL_PTR_APPEND_SUFFIX (1))
/* The least significant bit is set to mark that no array has been
allocated yet */
#define _cogl_bitmask_from_bits(bits) \
- ((void *) ((((unsigned long) (bits)) << 1UL) | 1UL))
+ ((void *) ((((size_t) (bits)) << COGL_PTR_APPEND_SUFFIX (1)) | COGL_PTR_APPEND_SUFFIX (1)))
/* Internal helper macro to determine whether this bitmask has a
GArray allocated or whether the pointer is just used directly */
#define _cogl_bitmask_has_array(bitmask) \
- (!(_cogl_bitmask_to_number (bitmask) & 1UL))
+ (!(_cogl_bitmask_to_number (bitmask) & COGL_PTR_APPEND_SUFFIX (1)))
/* Number of bits we can use before needing to allocate an array */
#define COGL_BITMASK_MAX_DIRECT_BITS (sizeof (unsigned long) * 8 - 1)
@@ -173,7 +179,7 @@ _cogl_bitmask_get (const CoglBitmask *bitmask, unsigned int bit_num)
else if (bit_num >= COGL_BITMASK_MAX_DIRECT_BITS)
return FALSE;
else
- return !!(_cogl_bitmask_to_bits (bitmask) & (1UL << bit_num));
+ return !!(_cogl_bitmask_to_bits (bitmask) & (COGL_PTR_APPEND_SUFFIX (1) << bit_num));
}
/*
@@ -192,10 +198,10 @@ _cogl_bitmask_set (CoglBitmask *bitmask, unsigned int bit_num, CoglBool value)
_cogl_bitmask_set_in_array (bitmask, bit_num, value);
else if (value)
*bitmask = _cogl_bitmask_from_bits (_cogl_bitmask_to_bits (bitmask) |
- (1UL << bit_num));
+ (COGL_PTR_APPEND_SUFFIX (1) << bit_num));
else
*bitmask = _cogl_bitmask_from_bits (_cogl_bitmask_to_bits (bitmask) &
- ~(1UL << bit_num));
+ ~(COGL_PTR_APPEND_SUFFIX (1) << bit_num));
}
/*
@@ -304,7 +310,7 @@ _cogl_bitmask_popcount_upto (const CoglBitmask *bitmask,
return _cogl_util_popcountl (_cogl_bitmask_to_bits (bitmask));
else
return _cogl_util_popcountl (_cogl_bitmask_to_bits (bitmask) &
- ((1UL << upto) - 1));
+ ((COGL_PTR_APPEND_SUFFIX (1) << upto) - 1));
}
COGL_END_DECLS
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]