Print a user-friendly message when `lunch` cannot use the default product.

In some environments (e.g. with the master-art branch), the default
product (aosp_arm-eng) cannot be built, and thus prevents `lunch` from
printing the lunch menu (as it cannot initialize the build system in
order to fetch the common lunch choices). When this happens, show an
explicit error message from `lunch` instead of a Soong UI error.

Test: Check that this command line displays the expected error message:
        unset TARGET_PRODUCT && . build/envsetup.sh && lunch
Bug: 152762648
Change-Id: I40c66bca5b075d88dbc8364b36b2db713e6ad93e
This commit is contained in:
Roland Levillain 2020-03-31 16:11:05 +01:00
parent 8459ede56d
commit 23c46cf424
1 changed files with 18 additions and 3 deletions

View File

@ -119,13 +119,13 @@ function get_build_var()
if [ "$BUILD_VAR_CACHE_READY" = "true" ] if [ "$BUILD_VAR_CACHE_READY" = "true" ]
then then
eval "echo \"\${var_cache_$1}\"" eval "echo \"\${var_cache_$1}\""
return return 0
fi fi
local T=$(gettop) local T=$(gettop)
if [ ! "$T" ]; then if [ ! "$T" ]; then
echo "Couldn't locate the top of the tree. Try setting TOP." >&2 echo "Couldn't locate the top of the tree. Try setting TOP." >&2
return return 1
fi fi
(\cd $T; build/soong/soong_ui.bash --dumpvar-mode $1) (\cd $T; build/soong/soong_ui.bash --dumpvar-mode $1)
} }
@ -576,10 +576,25 @@ function add_lunch_combo()
function print_lunch_menu() function print_lunch_menu()
{ {
local uname=$(uname) local uname=$(uname)
local choices=$(TARGET_BUILD_APPS= get_build_var COMMON_LUNCH_CHOICES) local choices
choices=$(TARGET_BUILD_APPS= get_build_var COMMON_LUNCH_CHOICES 2>/dev/null)
local ret=$?
echo echo
echo "You're building on" $uname echo "You're building on" $uname
echo echo
if [ $ret -ne 0 ]
then
echo "Warning: Cannot display lunch menu."
echo
echo "Note: You can invoke lunch with an explicit target:"
echo
echo " usage: lunch [target]" >&2
echo
return
fi
echo "Lunch menu... pick a combo:" echo "Lunch menu... pick a combo:"
local i=1 local i=1