Implement AAPT Bundle format
AAPT will scan XML files looking for the <aapt:attr> XML tag. <!-- @layout/bundle.xml --> <ImageView xmlns:aapt="http://schemas.android.com/aapt"> <aapt:attr name="android:src"> <vector android:pathData="..." ...> </vector> </aapt:attr> </ImageView> The SINGLE child element of the <aapt:attr> tag is extracted into its own top level resource. It is given a generated name. The parent element of <aapt:attr> is then given the resource attribute that was assigned to the `name' attribute. The value is set to a reference to the generated resource. <!-- @layout/bundle.xml --> <ImageView android:src="@drawable/bundle_1.xml"> </ImageView> <!-- @layout/bundle_1.xml --> <vector android:pathData="..." ...> </vector> Bug:22627686 Change-Id: I8575fc4f739011402662fbf6b3db96df0012f598
This commit is contained in:
@ -1537,12 +1537,20 @@ status_t buildResources(Bundle* bundle, const sp<AaptAssets>& assets, sp<ApkBuil
|
||||
std::queue<CompileResourceWorkItem>& workQueue = table.getWorkQueue();
|
||||
while (!workQueue.empty()) {
|
||||
CompileResourceWorkItem& workItem = workQueue.front();
|
||||
err = compileXmlFile(bundle, assets, workItem.resourceName, workItem.file, &table, xmlFlags);
|
||||
int xmlCompilationFlags = xmlFlags | XML_COMPILE_PARSE_VALUES
|
||||
| XML_COMPILE_ASSIGN_ATTRIBUTE_IDS;
|
||||
if (!workItem.needsCompiling) {
|
||||
xmlCompilationFlags &= ~XML_COMPILE_ASSIGN_ATTRIBUTE_IDS;
|
||||
xmlCompilationFlags &= ~XML_COMPILE_PARSE_VALUES;
|
||||
}
|
||||
err = compileXmlFile(bundle, assets, workItem.resourceName, workItem.xmlRoot,
|
||||
workItem.file, &table, xmlCompilationFlags);
|
||||
|
||||
if (err == NO_ERROR) {
|
||||
assets->addResource(workItem.resPath.getPathLeaf(),
|
||||
workItem.resPath,
|
||||
workItem.file,
|
||||
workItem.file->getResourceType());
|
||||
workItem.resPath,
|
||||
workItem.file,
|
||||
workItem.file->getResourceType());
|
||||
} else {
|
||||
hasErrors = true;
|
||||
}
|
||||
@ -1737,9 +1745,7 @@ status_t buildResources(Bundle* bundle, const sp<AaptAssets>& assets, sp<ApkBuil
|
||||
manifestFile->getGroupEntry(),
|
||||
manifestFile->getResourceType());
|
||||
err = compileXmlFile(bundle, assets, String16(), manifestFile,
|
||||
outManifestFile, &table,
|
||||
XML_COMPILE_ASSIGN_ATTRIBUTE_IDS
|
||||
| XML_COMPILE_STRIP_WHITESPACE | XML_COMPILE_STRIP_RAW_VALUES);
|
||||
outManifestFile, &table, XML_COMPILE_STANDARD_RESOURCE & ~XML_COMPILE_STRIP_COMMENTS);
|
||||
if (err < NO_ERROR) {
|
||||
return err;
|
||||
}
|
||||
|
Reference in New Issue
Block a user