]> git.saurik.com Git - android/aapt.git/commitdiff
Fix bitmask in aapt's StringPool length construction
authorKenny Root <kenny@the-b.org>
Fri, 21 Aug 2009 20:23:45 +0000 (15:23 -0500)
committerKenny Root <kroot@google.com>
Fri, 4 Dec 2009 21:40:54 +0000 (13:40 -0800)
The StringPool indicates the length of a string with a 16-bit
integer. If the length of the string is greater than 0x7FFF,
it splits it into two 16-bit integers with the first one
having the high bit set.

The length calculation has a small bug that masks off the
19 bits instead of the first 15 bits as intended.

StringPool.cpp

index 878d3b1fea7e1cd902c73fae6669c677034ef125..715170aedfebfebe39c98c5e42b1b73eb23fc94d 100644 (file)
@@ -228,7 +228,7 @@ status_t StringPool::writeStringBlock(const sp<AaptFile>& pool)
         }
         dat += (preSize+strPos)/sizeof(uint16_t);
         if (lenSize > sizeof(uint16_t)) {
-            *dat = htods(0x8000 | ((strSize>>16)&0x7ffff));
+            *dat = htods(0x8000 | ((strSize>>16)&0x7fff));
             dat++;
         }
         *dat++ = htods(strSize);