当执行 lunch 命令时,如果不再显示传统的构建选项列表,而是提示"Cannot display lunch menu"或直接进入需要手动输入格式的模式,这通常是由于以下两个主要原因造成的:
1. 编译环境未正确初始化
这是最常见的原因。lunch 命令是由 build/envsetup.sh 脚本定义的,如果该脚本未被加载,系统就无法识别 lunch 命令。
-
解决方法 :请确保您当前位于 Android 源代码的根目录 下,然后执行以下命令来初始化编译环境:
source build/envsetup.sh
或者使用其简写:./build/envsetup.sh
执行成功后,再运行lunch命令即可。建议将此命令添加到您的 shell 配置文件(如.bashrc)中,以避免每次打开终端都重复执行。1
2. 使用了较新的 AOSP 版本(推荐手动指定格式)
根据 2025 年及之后的 AOSP 版本更新,lunch 命令的行为发生了变化。它不再自动显示一个可选择的菜单列表,而是要求用户直接手动指定完整的构建目标格式。
-
解决方法 :您需要按照
lunch TARGET_PRODUCT-TARGET_RELEASE-TARGET_BUILD_VARIANT的格式来指定构建目标。- **
TARGET_PRODUCT** (产品): 使用list_products命令来查看可用的产品列表。 - **
TARGET_RELEASE** (版本): 使用list_releases [product]命令来查看指定产品的可用版本(例如list_releases aosp_arm)。 - **
TARGET_BUILD_VARIANT** (构建类型): 通常从user、userdebug、eng中选择。user适用于发布版本,userdebug和eng适用于调试版本。23
例如,要为 ARM 架构构建一个调试版本,您需要输入:
lunch aosp_arm-eng或者,如果您想构建一个特定的汽车 SDK 版本:
lunch sdk_car_x86_64-trunk_staging-userdebug注意:对于新版本,建议避免使用
aosp_current这样的不稳定分支,而应选择如trunk_staging等更稳定的版本 - **