]> granicus.if.org Git - icu/commitdiff
ICU-8310 Use inline function to avoid dereferencing type-punned pointer warning
authorMichael Ow <mow@svn.icu-project.org>
Fri, 22 Jul 2011 22:02:57 +0000 (22:02 +0000)
committerMichael Ow <mow@svn.icu-project.org>
Fri, 22 Jul 2011 22:02:57 +0000 (22:02 +0000)
X-SVN-Rev: 30410

icu4c/source/layout/ExtensionSubtables.cpp

index 6011154bf68abcc54a56c0239c59b2c6192da8d0..5da918daa3eb21e1a9b106d8a4d416201b04b983 100644 (file)
@@ -1,7 +1,7 @@
 /*
  * %W% %E%
  *
- * (C) Copyright IBM Corp. 2008-2010 - All Rights Reserved
+ * (C) Copyright IBM Corp. 2008-2011 - All Rights Reserved
  *
  */
 
 U_NAMESPACE_BEGIN
 
 // read a 32-bit value that might only be 16-bit-aligned in memory
-#define READ_LONG(code) (le_uint32)((SWAPW(*(le_uint16*)&code) << 16) + SWAPW(*(((le_uint16*)&code) + 1)))
+static inline le_uint32 READ_LONG(le_uint32 code) {
+    le_uint16* first = ((le_uint16*)&code);
+    le_uint16* second = (((le_uint16*)&code) + 1);
+    return (le_uint32)(SWAPW(*first << 16) + SWAPW(*second));
+}
 
 // FIXME: should look at the format too... maybe have a sub-class for it?
 le_uint32 ExtensionSubtable::process(const LookupProcessor *lookupProcessor, le_uint16 lookupType,
@@ -28,7 +32,7 @@ le_uint32 ExtensionSubtable::process(const LookupProcessor *lookupProcessor, le_
 
     le_uint16 elt = SWAPW(extensionLookupType);
 
-    if (elt != lookupType) {
+    if (elt != lookupType) {      
         le_uint32 extOffset = READ_LONG(extensionOffset);
         LookupSubtable *subtable = (LookupSubtable *) ((char *) this + extOffset);