我有兴趣尝试使用 aapt2 从命令行编译 Android 应用程序。当我尝试执行以下操作时,链接约束布局库时遇到问题aapt2 link
命令。该程序从 Android studio/gradle 成功构建。如何使 gradle 命令行调用向我显示它正在运行的 aapt2 命令?
作为记录,我尝试运行 ./gradlew assembleDebug --debug,我所能看到的只是对 aapt2-proto 库的调用。
Link
该命令会有点复杂,并且取决于很多因素(例如您的资源、项目的依赖项、使用的标志等),因此获取完整命令的最简单方法是实际“破坏”资源。
编辑你的资源/值/strings.xml文件包含:
<string name="incorrect">@string/idontexist</string>
转到项目目录并运行“gradlew clean assembleDebug”。 AAPT2 在链接期间将失败,Android Gradle 插件将打印出所使用的完整命令。
我使用的是 3.2.0-alpha13 版本,它为我提供了完整的命令:
error: failed linking references.
Command: <path>/.gradle/caches/transforms-1/files-1.1/aapt2-3.2.0-alpha13-4662957-linux.jar/cbe84ab07c48b199e5fe8d202dd5845e/aapt2-3.2.0-alpha13-4662957-linux/aapt2 link -I\
<path>/Android/Sdk/platforms/android-27/android.jar\
--manifest\
<path>/AndroidStudioProjects/Library/app/build/intermediates/merged_manifests/debug/processDebugManifest/merged/AndroidManifest.xml\
-o\
<path>/AndroidStudioProjects/Library/app/build/intermediates/processed_res/debug/processDebugResources/out/resources-debug.ap_\
-R\
@<path>/AndroidStudioProjects/Library/app/build/intermediates/incremental/processDebugResources/resources-list-for-resources-debug.ap_.txt\
--auto-add-overlay\
--java\
<path>/AndroidStudioProjects/Library/app/build/generated/not_namespaced_r_class_sources/debug/processDebugResources/r\
--proguard-main-dex\
<path>/AndroidStudioProjects/Library/app/build/intermediates/legacy_multidex_aapt_derived_proguard_rules/debug/processDebugResources/manifest_keep.txt\
--custom-package\
com.example.foo.bar\
-0\
apk\
--output-text-symbols\
<path>/AndroidStudioProjects/Library/app/build/intermediates/symbols/debug/R.txt\
--no-version-vectors
Daemon: AAPT2 aapt2-3.2.0-alpha13-4662957-linux Daemon #0
此处用于 AAPT2 的标志:
-
-I:平台的android.jar的路径
-
- 显现:清单文件(AGP 使用合并的清单,而不仅仅是源中的清单)
-
-o: 输出文件
-
-R: 资源。通常你会一个接一个地传递,但由于这里有很多,它们被写入一个文件,然后该文件被传递到 AAPT2 (这就是为什么路径前面有“@”符号)
-
--自动添加覆盖: 允许叠加
-
--java:R.java 的输出目录
-
--proguard-main-dex:主 dex 的 Proguard 规则的输出文件
-
--自定义包:R类的包
-
-0: 不要压缩这些扩展名
-
--输出文本符号:R.txt 的输出文件
-
--无版本向量:矢量绘图没有自动版本控制
其他可能对您有用的标志:
-
-v: 详细记录
-
-A:包含您想要放入 APK 文件中的资源的目录,它们不会被处理或压缩,只是按原样放入输出文件中
-
-h: 打印出帮助
Compile
编译命令非常简单。您基本上告诉 AAPT2 要编译哪个单个文件以及在哪里输出它。
<path>aapt2 compile -o /path/to/output/dir /path/to/file/to/compile.xml
编译的标志是:
-
-o:编译后的文件放置的目录
-
--伪本地化:生成伪语言环境的源
-
--legacy:导致 AAPT2 更加宽松,并将某些错误视为警告(就像 AAPT1 所做的那样)
-
-v: 详细记录
-
-h: 打印出帮助
要记住的一件事是,编译的文件是二进制 .flat 文件,输出名称基于输入名称和文件的父目录名称。这意味着如果输入文件是res/drawable-450dpi/img.png输出文件将是可绘制-450dpi_img.png.flat。编译值文件的扩展名是“arsc.flat”,而不仅仅是“.flat”,因此文件res/values-en/strings.xml将被编译为值-en_strings.arsc.flat。这是由 AAPT2 自动完成的,因此您无需担心,但最好了解一下,以防您稍后需要找到编译后的文件。
关于编译的另一个有趣的事实是,它在记住输入文件是什么(以及 XML 文件的行号)方面非常有用,因此如果链接失败,错误将不会指向 .flat 文件,而是指向原始输入文件代替。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)