diff options
author | Adam Lesinski <adamlesinski@google.com> | 2014-08-15 17:19:51 +0000 |
---|---|---|
committer | Android (Google) Code Review <android-gerrit@google.com> | 2014-08-15 04:37:53 +0000 |
commit | 89147ed84b140d83e144ad9eaa568cc9c6fb514c (patch) | |
tree | 176f1f15bcd79de7ebe99a7d8684e8bd104ba6ce | |
parent | 261e240c05a32aec20022ae3f527dafea5f3f0d8 (diff) | |
parent | 18560886cbb7825c1bb034c96e5d0cd4dbdbb8ee (diff) | |
download | frameworks_base-89147ed84b140d83e144ad9eaa568cc9c6fb514c.zip frameworks_base-89147ed84b140d83e144ad9eaa568cc9c6fb514c.tar.gz frameworks_base-89147ed84b140d83e144ad9eaa568cc9c6fb514c.tar.bz2 |
Merge "Revert "Fix aapt dump for APKs with no resources"" into lmp-dev
-rw-r--r-- | libs/androidfw/ResourceTypes.cpp | 25 | ||||
-rw-r--r-- | libs/androidfw/tests/ResTable_test.cpp | 17 |
2 files changed, 17 insertions, 25 deletions
diff --git a/libs/androidfw/ResourceTypes.cpp b/libs/androidfw/ResourceTypes.cpp index 1316cb8..f963a4e 100644 --- a/libs/androidfw/ResourceTypes.cpp +++ b/libs/androidfw/ResourceTypes.cpp @@ -2860,16 +2860,17 @@ struct ResTable::Type struct ResTable::Package { Package(ResTable* _owner, const Header* _header, const ResTable_package* _package) - : owner(_owner), header(_header), typeIdOffset(0) { - if (_package != NULL && dtohs(_package->header.headerSize) == sizeof(_package)) { + : owner(_owner), header(_header), package(_package), typeIdOffset(0) { + if (dtohs(package->header.headerSize) == sizeof(package)) { // The package structure is the same size as the definition. // This means it contains the typeIdOffset field. - typeIdOffset = _package->typeIdOffset; + typeIdOffset = package->typeIdOffset; } } const ResTable* const owner; const Header* const header; + const ResTable_package* const package; ResStringPool typeStrings; ResStringPool keyStrings; @@ -3368,10 +3369,6 @@ status_t ResTable::addEmpty(const int32_t cookie) { header->header = (const ResTable_header*) resHeader; mHeaders.add(header); - - PackageGroup* pg = new PackageGroup(this, String16(), 0); - pg->packages.add(new Package(this, header, NULL)); - mPackageGroups.add(pg); return (mError=NO_ERROR); } @@ -5940,7 +5937,7 @@ status_t ResTable::createIdmap(const ResTable& overlay, *outSize += 2 * sizeof(uint16_t); // overlay packages are assumed to contain only one package group - const String16 overlayPackage(overlay.mPackageGroups[0]->name); + const String16 overlayPackage(overlay.mPackageGroups[0]->packages[0]->package->name); for (size_t typeIndex = 0; typeIndex < pg->types.size(); ++typeIndex) { const TypeList& typeList = pg->types[typeIndex]; @@ -6215,6 +6212,11 @@ void ResTable::print(bool inclValues) const if (mError != 0) { printf("mError=0x%x (%s)\n", mError, strerror(mError)); } +#if 0 + char localeStr[RESTABLE_MAX_LOCALE_LEN]; + mParams.getBcp47Locale(localeStr); + printf("mParams=%s,\n" localeStr); +#endif size_t pgCount = mPackageGroups.size(); printf("Package Groups (%d)\n", (int)pgCount); for (size_t pgIndex=0; pgIndex<pgCount; pgIndex++) { @@ -6223,6 +6225,13 @@ void ResTable::print(bool inclValues) const (int)pgIndex, pg->id, (int)pg->packages.size(), String8(pg->name).string()); + size_t pkgCount = pg->packages.size(); + for (size_t pkgIndex=0; pkgIndex<pkgCount; pkgIndex++) { + const Package* pkg = pg->packages[pkgIndex]; + printf(" Package %d id=%d name=%s\n", (int)pkgIndex, + pkg->package->id, String8(String16(pkg->package->name)).string()); + } + for (size_t typeIndex=0; typeIndex < pg->types.size(); typeIndex++) { const TypeList& typeList = pg->types[typeIndex]; if (typeList.isEmpty()) { diff --git a/libs/androidfw/tests/ResTable_test.cpp b/libs/androidfw/tests/ResTable_test.cpp index 68c228e..8016a82 100644 --- a/libs/androidfw/tests/ResTable_test.cpp +++ b/libs/androidfw/tests/ResTable_test.cpp @@ -195,21 +195,4 @@ TEST(ResTableTest, resourceIsOverridenWithBetterConfig) { ASSERT_EQ(uint32_t(400), val.data); } -TEST(ResTableTest, emptyTableHasSensibleDefaults) { - const int32_t expectedCookie = 1; - - ResTable table; - ASSERT_EQ(NO_ERROR, table.addEmpty(expectedCookie)); - - ASSERT_EQ(uint32_t(1), table.getTableCount()); - ASSERT_EQ(uint32_t(1), table.getBasePackageCount()); - ASSERT_EQ(expectedCookie, table.getTableCookie(0)); - - const DynamicRefTable* dynamicRefTable = table.getDynamicRefTableForCookie(expectedCookie); - ASSERT_TRUE(dynamicRefTable != NULL); - - Res_value val; - ASSERT_LT(table.getResource(base::R::integer::number1, &val, MAY_NOT_BE_BAG), 0); -} - } |