blob: 212b0499a4a73e20aa39aca5e3c13ef0085e0f02 [file] [log] [blame]
Joe Onorato344e4042022-12-05 15:15:36 -08001# Copyright (C) 2022 The Android Open Source Project
2#
3# Licensed under the Apache License, Version 2.0 (the "License");
4# you may not use this file except in compliance with the License.
5# You may obtain a copy of the License at
6#
7# http://www.apache.org/licenses/LICENSE-2.0
8#
9# Unless required by applicable law or agreed to in writing, software
10# distributed under the License is distributed on an "AS IS" BASIS,
11# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12# See the License for the specific language governing permissions and
13# limitations under the License.
14
15# gettop is duplicated here and in shell_utils.mk, because it's difficult
16# to find shell_utils.make without it for all the novel ways this file can be
17# sourced. Other common functions should only be in one place or the other.
18function _gettop_once
19{
20 local TOPFILE=build/make/core/envsetup.mk
21 if [ -n "$TOP" -a -f "$TOP/$TOPFILE" ] ; then
22 # The following circumlocution ensures we remove symlinks from TOP.
23 (cd "$TOP"; PWD= /bin/pwd)
24 else
25 if [ -f $TOPFILE ] ; then
26 # The following circumlocution (repeated below as well) ensures
27 # that we record the true directory name and not one that is
28 # faked up with symlink names.
29 PWD= /bin/pwd
30 else
31 local HERE=$PWD
32 local T=
33 while [ \( ! \( -f $TOPFILE \) \) -a \( "$PWD" != "/" \) ]; do
34 \cd ..
35 T=`PWD= /bin/pwd -P`
36 done
37 \cd "$HERE"
38 if [ -f "$T/$TOPFILE" ]; then
39 echo "$T"
40 fi
41 fi
42 fi
43}
44T=$(_gettop_once)
45if [ ! "$T" ]; then
46 echo "Couldn't locate the top of the tree. Always source build/envsetup.sh from the root of the tree." >&2
47 return 1
48fi
49IMPORTING_ENVSETUP=true source $T/build/make/shell_utils.sh
50
Ying Wang08800fd2016-03-03 20:57:21 -080051# Get all the build variables needed by this script in a single call to the build system.
Matt Alexanderd9c56562020-05-21 10:49:17 +000052function build_build_var_cache()
53{
Christopher Ferris55257d22017-03-23 11:08:58 -070054 local T=$(gettop)
Ying Wang08800fd2016-03-03 20:57:21 -080055 # Grep out the variable names from the script.
Michael Bestas971da5d2016-08-26 00:37:02 +030056 cached_vars=(`cat $T/build/envsetup.sh $T/vendor/omni/build/envsetup.sh | tr '()' ' ' | awk '{for(i=1;i<=NF;i++) if($i~/_get_build_var_cached/) print $(i+1)}' | sort -u | tr '\n' ' '`)
57 cached_abs_vars=(`cat $T/build/envsetup.sh $T/vendor/omni/build/envsetup.sh | tr '()' ' ' | awk '{for(i=1;i<=NF;i++) if($i~/_get_abs_build_var_cached/) print $(i+1)}' | sort -u | tr '\n' ' '`)
Ying Wang08800fd2016-03-03 20:57:21 -080058 # Call the build system to dump the "<val>=<value>" pairs as a shell script.
Steven Moreland05402962018-01-05 12:13:11 -080059 build_dicts_script=`\builtin cd $T; build/soong/soong_ui.bash --dumpvars-mode \
Jim Tanga881a252018-06-19 16:34:41 +080060 --vars="${cached_vars[*]}" \
61 --abs-vars="${cached_abs_vars[*]}" \
Dan Willemsenaf88c412017-07-14 11:29:44 -070062 --var-prefix=var_cache_ \
63 --abs-var-prefix=abs_var_cache_`
Ying Wang08800fd2016-03-03 20:57:21 -080064 local ret=$?
Matt Alexanderd9c56562020-05-21 10:49:17 +000065 if [ $ret -ne 0 ]
66 then
Ying Wang08800fd2016-03-03 20:57:21 -080067 unset build_dicts_script
68 return $ret
69 fi
Dan Willemsenaf88c412017-07-14 11:29:44 -070070 # Execute the script to store the "<val>=<value>" pairs as shell variables.
Ying Wang08800fd2016-03-03 20:57:21 -080071 eval "$build_dicts_script"
Ying Wang08800fd2016-03-03 20:57:21 -080072 ret=$?
Ying Wangf0cb3972016-03-04 13:56:23 -080073 unset build_dicts_script
Matt Alexanderd9c56562020-05-21 10:49:17 +000074 if [ $ret -ne 0 ]
75 then
Ying Wang08800fd2016-03-03 20:57:21 -080076 return $ret
77 fi
78 BUILD_VAR_CACHE_READY="true"
79}
80
Ying Wangf0cb3972016-03-04 13:56:23 -080081# Delete the build var cache, so that we can still call into the build system
Ying Wang08800fd2016-03-03 20:57:21 -080082# to get build variables not listed in this script.
Matt Alexanderd9c56562020-05-21 10:49:17 +000083function destroy_build_var_cache()
84{
Ying Wang08800fd2016-03-03 20:57:21 -080085 unset BUILD_VAR_CACHE_READY
Christopher Ferris55257d22017-03-23 11:08:58 -070086 local v
Ying Wang08800fd2016-03-03 20:57:21 -080087 for v in $cached_vars; do
88 unset var_cache_$v
89 done
90 unset cached_vars
91 for v in $cached_abs_vars; do
92 unset abs_var_cache_$v
93 done
94 unset cached_abs_vars
95}
96
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -070097# Get the value of a build variable as an absolute path.
Joe Onorato0e68f702024-05-24 14:19:21 -070098function _get_abs_build_var_cached()
Matt Alexanderd9c56562020-05-21 10:49:17 +000099{
100 if [ "$BUILD_VAR_CACHE_READY" = "true" ]
101 then
Vishwath Mohan7d35f002016-03-11 10:00:40 -0800102 eval "echo \"\${abs_var_cache_$1}\""
Timi0469c3f2021-04-15 16:41:18 +0200103 return
Ying Wang08800fd2016-03-03 20:57:21 -0800104 fi
105
Christopher Ferris55257d22017-03-23 11:08:58 -0700106 local T=$(gettop)
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700107 if [ ! "$T" ]; then
108 echo "Couldn't locate the top of the tree. Try setting TOP." >&2
109 return
110 fi
Dan Willemsenaf88c412017-07-14 11:29:44 -0700111 (\cd $T; build/soong/soong_ui.bash --dumpvar-mode --abs $1)
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700112}
113
114# Get the exact value of a build variable.
Joe Onorato0e68f702024-05-24 14:19:21 -0700115function _get_build_var_cached()
Matt Alexanderd9c56562020-05-21 10:49:17 +0000116{
117 if [ "$BUILD_VAR_CACHE_READY" = "true" ]
118 then
Vishwath Mohan7d35f002016-03-11 10:00:40 -0800119 eval "echo \"\${var_cache_$1}\""
Roland Levillain23c46cf2020-03-31 16:11:05 +0100120 return 0
Ying Wang08800fd2016-03-03 20:57:21 -0800121 fi
122
Christopher Ferris55257d22017-03-23 11:08:58 -0700123 local T=$(gettop)
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700124 if [ ! "$T" ]; then
125 echo "Couldn't locate the top of the tree. Try setting TOP." >&2
Roland Levillain23c46cf2020-03-31 16:11:05 +0100126 return 1
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700127 fi
Dan Willemsenaf88c412017-07-14 11:29:44 -0700128 (\cd $T; build/soong/soong_ui.bash --dumpvar-mode $1)
The Android Open Source Projectdcc08f02008-12-17 18:03:49 -0800129}
130
Joe Onorato32b2aa32024-05-14 13:54:13 -0700131# This logic matches envsetup.mk
132function get_host_prebuilt_prefix
133{
134 local un=$(uname)
135 if [[ $un == "Linux" ]] ; then
136 echo linux-x86
137 elif [[ $un == "Darwin" ]] ; then
138 echo darwin-x86
139 else
140 echo "Error: Invalid host operating system: $un" 1>&2
141 fi
142}
143
Joe Onorato7c3a77f2022-12-05 13:05:14 -0800144# Add directories to PATH that are dependent on the lunch target.
145# For directories that are not lunch-specific, add them in set_global_paths
146function set_lunch_paths()
Matt Alexanderd9c56562020-05-21 10:49:17 +0000147{
Christopher Ferris55257d22017-03-23 11:08:58 -0700148 local T=$(gettop)
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700149 if [ ! "$T" ]; then
150 echo "Couldn't locate the top of the tree. Try setting TOP."
151 return
152 fi
153
154 ##################################################################
155 # #
156 # Read me before you modify this code #
157 # #
Joe Onorato7c3a77f2022-12-05 13:05:14 -0800158 # This function sets ANDROID_LUNCH_BUILD_PATHS to what it is #
159 # adding to PATH, and the next time it is run, it removes that #
160 # from PATH. This is required so lunch can be run more than #
161 # once and still have working paths. #
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700162 # #
163 ##################################################################
164
Joe Onorato7c3a77f2022-12-05 13:05:14 -0800165 # Note: on windows/cygwin, ANDROID_LUNCH_BUILD_PATHS will contain spaces
Raphael Mollc639c782011-06-20 17:25:01 -0700166 # due to "C:\Program Files" being in the path.
167
Kevin Dagostino185109b2024-01-11 17:39:02 +0000168 # Handle compat with the old ANDROID_BUILD_PATHS variable.
Joe Onorato7c3a77f2022-12-05 13:05:14 -0800169 # TODO: Remove this after we think everyone has lunched again.
170 if [ -z "$ANDROID_LUNCH_BUILD_PATHS" -a -n "$ANDROID_BUILD_PATHS" ] ; then
171 ANDROID_LUNCH_BUILD_PATHS="$ANDROID_BUILD_PATHS"
172 ANDROID_BUILD_PATHS=
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700173 fi
Matt Alexanderd9c56562020-05-21 10:49:17 +0000174 if [ -n "$ANDROID_PRE_BUILD_PATHS" ] ; then
Doug Zongker29034982011-04-22 08:16:56 -0700175 export PATH=${PATH/$ANDROID_PRE_BUILD_PATHS/}
Ying Wangaa1c9b52012-11-26 20:51:59 -0800176 # strip leading ':', if any
177 export PATH=${PATH/:%/}
Joe Onorato7c3a77f2022-12-05 13:05:14 -0800178 ANDROID_PRE_BUILD_PATHS=
Jeff Hamilton4a1c70e2010-06-21 18:26:38 -0500179 fi
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700180
Joe Onorato7c3a77f2022-12-05 13:05:14 -0800181 # Out with the old...
182 if [ -n "$ANDROID_LUNCH_BUILD_PATHS" ] ; then
183 export PATH=${PATH/$ANDROID_LUNCH_BUILD_PATHS/}
184 fi
Ben Chengfba67bf2014-02-25 10:27:07 -0800185
Joe Onorato7c3a77f2022-12-05 13:05:14 -0800186 # And in with the new...
Joe Onorato0e68f702024-05-24 14:19:21 -0700187 ANDROID_LUNCH_BUILD_PATHS=$(_get_abs_build_var_cached SOONG_HOST_OUT_EXECUTABLES)
188 ANDROID_LUNCH_BUILD_PATHS+=:$(_get_abs_build_var_cached HOST_OUT_EXECUTABLES)
Yueyao Zhuefc786a2017-04-07 14:11:54 -0700189
Joe Onorato7c3a77f2022-12-05 13:05:14 -0800190 # Append llvm binutils prebuilts path to ANDROID_LUNCH_BUILD_PATHS.
Joe Onorato0e68f702024-05-24 14:19:21 -0700191 local ANDROID_LLVM_BINUTILS=$(_get_abs_build_var_cached ANDROID_CLANG_PREBUILTS)/llvm-binutils-stable
Joe Onorato7c3a77f2022-12-05 13:05:14 -0800192 ANDROID_LUNCH_BUILD_PATHS+=:$ANDROID_LLVM_BINUTILS
David 'Digit' Turner94d16e52014-05-05 16:13:50 +0200193
Stephen Hinesaa8d72c2020-02-04 09:15:18 -0800194 # Set up ASAN_SYMBOLIZER_PATH for SANITIZE_HOST=address builds.
195 export ASAN_SYMBOLIZER_PATH=$ANDROID_LLVM_BINUTILS/llvm-symbolizer
196
Joe Onorato7c3a77f2022-12-05 13:05:14 -0800197 # Append asuite prebuilts path to ANDROID_LUNCH_BUILD_PATHS.
Joe Onorato0e68f702024-05-24 14:19:21 -0700198 local os_arch=$(_get_build_var_cached HOST_PREBUILT_TAG)
Joe Onorato7c3a77f2022-12-05 13:05:14 -0800199 ANDROID_LUNCH_BUILD_PATHS+=:$T/prebuilts/asuite/acloud/$os_arch
200 ANDROID_LUNCH_BUILD_PATHS+=:$T/prebuilts/asuite/aidegen/$os_arch
201 ANDROID_LUNCH_BUILD_PATHS+=:$T/prebuilts/asuite/atest/$os_arch
The Android Open Source Projectdcc08f02008-12-17 18:03:49 -0800202
Joe Onorato0e68f702024-05-24 14:19:21 -0700203 export ANDROID_JAVA_HOME=$(_get_abs_build_var_cached ANDROID_JAVA_HOME)
Colin Crosse97e6932017-06-30 16:01:45 -0700204 export JAVA_HOME=$ANDROID_JAVA_HOME
Joe Onorato0e68f702024-05-24 14:19:21 -0700205 export ANDROID_JAVA_TOOLCHAIN=$(_get_abs_build_var_cached ANDROID_JAVA_TOOLCHAIN)
Joe Onorato7c3a77f2022-12-05 13:05:14 -0800206 ANDROID_LUNCH_BUILD_PATHS+=:$ANDROID_JAVA_TOOLCHAIN
207
208 # Fix up PYTHONPATH
209 if [ -n $ANDROID_PYTHONPATH ]; then
210 export PYTHONPATH=${PYTHONPATH//$ANDROID_PYTHONPATH/}
211 fi
Dan Albert0d6d3592023-01-26 00:07:03 +0000212 # //development/python-packages contains both a pseudo-PYTHONPATH which
213 # mimics an already assembled venv, but also contains real Python packages
214 # that are not in that layout until they are installed. We can fake it for
215 # the latter type by adding the package source directories to the PYTHONPATH
216 # directly. For the former group, we only need to add the python-packages
217 # directory itself.
218 #
219 # This could be cleaned up by converting the remaining packages that are in
220 # the first category into a typical python source layout (that is, another
221 # layer of directory nesting) and automatically adding all subdirectories of
222 # python-packages to the PYTHONPATH instead of manually curating this. We
223 # can't convert the packages like adb to the other style because doing so
224 # would prevent exporting type info from those packages.
225 #
226 # http://b/266688086
Dan Albert426ac692023-05-16 22:59:55 +0000227 export ANDROID_PYTHONPATH=$T/development/python-packages/adb:$T/development/python-packages/gdbrunner:$T/development/python-packages:
Joe Onorato7c3a77f2022-12-05 13:05:14 -0800228 if [ -n $VENDOR_PYTHONPATH ]; then
229 ANDROID_PYTHONPATH=$ANDROID_PYTHONPATH$VENDOR_PYTHONPATH
230 fi
231 export PYTHONPATH=$ANDROID_PYTHONPATH$PYTHONPATH
Jeff Hamilton4a1c70e2010-06-21 18:26:38 -0500232
The Android Open Source Projectdcc08f02008-12-17 18:03:49 -0800233 unset ANDROID_PRODUCT_OUT
Joe Onorato0e68f702024-05-24 14:19:21 -0700234 export ANDROID_PRODUCT_OUT=$(_get_abs_build_var_cached PRODUCT_OUT)
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700235 export OUT=$ANDROID_PRODUCT_OUT
236
Jeff Brown8fd5cce2011-03-24 17:03:06 -0700237 unset ANDROID_HOST_OUT
Joe Onorato0e68f702024-05-24 14:19:21 -0700238 export ANDROID_HOST_OUT=$(_get_abs_build_var_cached HOST_OUT)
Jeff Brown8fd5cce2011-03-24 17:03:06 -0700239
Jiyong Parkc02b1c42020-11-03 11:06:39 +0900240 unset ANDROID_SOONG_HOST_OUT
Joe Onorato0e68f702024-05-24 14:19:21 -0700241 export ANDROID_SOONG_HOST_OUT=$(_get_abs_build_var_cached SOONG_HOST_OUT)
Jiyong Parkc02b1c42020-11-03 11:06:39 +0900242
Simran Basidd050ed2017-02-13 13:46:48 -0800243 unset ANDROID_HOST_OUT_TESTCASES
Joe Onorato0e68f702024-05-24 14:19:21 -0700244 export ANDROID_HOST_OUT_TESTCASES=$(_get_abs_build_var_cached HOST_OUT_TESTCASES)
Simran Basidd050ed2017-02-13 13:46:48 -0800245
246 unset ANDROID_TARGET_OUT_TESTCASES
Joe Onorato0e68f702024-05-24 14:19:21 -0700247 export ANDROID_TARGET_OUT_TESTCASES=$(_get_abs_build_var_cached TARGET_OUT_TESTCASES)
Simran Basidd050ed2017-02-13 13:46:48 -0800248
Joe Onorato7c3a77f2022-12-05 13:05:14 -0800249 # Finally, set PATH
Joe Onorato1cb9e152022-12-05 16:56:15 -0800250 export PATH=$ANDROID_LUNCH_BUILD_PATHS:$PATH
Joe Onorato7c3a77f2022-12-05 13:05:14 -0800251}
252
253# Add directories to PATH that are NOT dependent on the lunch target.
254# For directories that are lunch-specific, add them in set_lunch_paths
255function set_global_paths()
256{
257 local T=$(gettop)
258 if [ ! "$T" ]; then
259 echo "Couldn't locate the top of the tree. Try setting TOP."
260 return
261 fi
262
263 ##################################################################
264 # #
265 # Read me before you modify this code #
266 # #
267 # This function sets ANDROID_GLOBAL_BUILD_PATHS to what it is #
268 # adding to PATH, and the next time it is run, it removes that #
269 # from PATH. This is required so envsetup.sh can be sourced #
270 # more than once and still have working paths. #
271 # #
272 ##################################################################
273
274 # Out with the old...
275 if [ -n "$ANDROID_GLOBAL_BUILD_PATHS" ] ; then
276 export PATH=${PATH/$ANDROID_GLOBAL_BUILD_PATHS/}
277 fi
278
279 # And in with the new...
Joe Onorato84e61d02024-02-02 22:53:39 -0800280 ANDROID_GLOBAL_BUILD_PATHS=$T/build/soong/bin
LaMont Jonese8a3be22024-02-12 09:55:41 -0800281 ANDROID_GLOBAL_BUILD_PATHS+=:$T/build/bazel/bin
Joe Onorato1cb9e152022-12-05 16:56:15 -0800282 ANDROID_GLOBAL_BUILD_PATHS+=:$T/development/scripts
283 ANDROID_GLOBAL_BUILD_PATHS+=:$T/prebuilts/devtools/tools
Joe Onorato7c3a77f2022-12-05 13:05:14 -0800284
285 # add kernel specific binaries
286 if [ $(uname -s) = Linux ] ; then
287 ANDROID_GLOBAL_BUILD_PATHS+=:$T/prebuilts/misc/linux-x86/dtc
288 ANDROID_GLOBAL_BUILD_PATHS+=:$T/prebuilts/misc/linux-x86/libufdt
289 fi
290
291 # If prebuilts/android-emulator/<system>/ exists, prepend it to our PATH
292 # to ensure that the corresponding 'emulator' binaries are used.
293 case $(uname -s) in
294 Darwin)
295 ANDROID_EMULATOR_PREBUILTS=$T/prebuilts/android-emulator/darwin-x86_64
296 ;;
297 Linux)
298 ANDROID_EMULATOR_PREBUILTS=$T/prebuilts/android-emulator/linux-x86_64
299 ;;
300 *)
301 ANDROID_EMULATOR_PREBUILTS=
302 ;;
303 esac
304 if [ -n "$ANDROID_EMULATOR_PREBUILTS" -a -d "$ANDROID_EMULATOR_PREBUILTS" ]; then
305 ANDROID_GLOBAL_BUILD_PATHS+=:$ANDROID_EMULATOR_PREBUILTS
306 export ANDROID_EMULATOR_PREBUILTS
307 fi
308
309 # Finally, set PATH
Joe Onorato1cb9e152022-12-05 16:56:15 -0800310 export PATH=$ANDROID_GLOBAL_BUILD_PATHS:$PATH
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700311}
312
Matt Alexanderd9c56562020-05-21 10:49:17 +0000313function printconfig()
314{
Christopher Ferris55257d22017-03-23 11:08:58 -0700315 local T=$(gettop)
The Android Open Source Projectdcc08f02008-12-17 18:03:49 -0800316 if [ ! "$T" ]; then
317 echo "Couldn't locate the top of the tree. Try setting TOP." >&2
318 return
319 fi
Joe Onorato0e68f702024-05-24 14:19:21 -0700320 _get_build_var_cached report_config
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700321}
322
Matt Alexanderd9c56562020-05-21 10:49:17 +0000323function set_stuff_for_environment()
324{
Joe Onorato7c3a77f2022-12-05 13:05:14 -0800325 set_lunch_paths
The Android Open Source Projectdcc08f02008-12-17 18:03:49 -0800326 set_sequence_number
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700327}
328
Matt Alexanderd9c56562020-05-21 10:49:17 +0000329function set_sequence_number()
330{
Colin Cross88737132017-03-21 17:41:03 -0700331 export BUILD_ENV_SEQUENCE_NUMBER=13
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700332}
333
Makoto Onukida971062018-06-18 10:15:19 -0700334# Takes a command name, and check if it's in ENVSETUP_NO_COMPLETION or not.
335function should_add_completion() {
Jim Tanga881a252018-06-19 16:34:41 +0800336 local cmd="$(basename $1| sed 's/_completion//' |sed 's/\.\(.*\)*sh$//')"
Makoto Onukida971062018-06-18 10:15:19 -0700337 case :"$ENVSETUP_NO_COMPLETION": in
Jim Tanga881a252018-06-19 16:34:41 +0800338 *:"$cmd":*)
339 return 1
340 ;;
Makoto Onukida971062018-06-18 10:15:19 -0700341 esac
342 return 0
343}
344
Matt Alexanderd9c56562020-05-21 10:49:17 +0000345function addcompletions()
346{
Ben Taitelbaum8c2c9cf2020-09-22 16:45:05 -0700347 local f=
Kenny Root52aa81c2011-07-15 11:07:06 -0700348
Jim Tanga881a252018-06-19 16:34:41 +0800349 # Keep us from trying to run in something that's neither bash nor zsh.
350 if [ -z "$BASH_VERSION" -a -z "$ZSH_VERSION" ]; then
Kenny Root52aa81c2011-07-15 11:07:06 -0700351 return
352 fi
353
354 # Keep us from trying to run in bash that's too old.
Jim Tanga881a252018-06-19 16:34:41 +0800355 if [ -n "$BASH_VERSION" -a ${BASH_VERSINFO[0]} -lt 3 ]; then
Kenny Root52aa81c2011-07-15 11:07:06 -0700356 return
357 fi
358
Jim Tanga881a252018-06-19 16:34:41 +0800359 local completion_files=(
MÃ¥rten Kongstadcb5c73f2022-05-04 14:08:12 +0000360 packages/modules/adb/adb.bash
Jim Tanga881a252018-06-19 16:34:41 +0800361 system/core/fastboot/fastboot.bash
Jim Tangb3fda302018-12-22 10:24:55 +0800362 tools/asuite/asuite.sh
Jim Tanga881a252018-06-19 16:34:41 +0800363 )
Makoto Onukida971062018-06-18 10:15:19 -0700364 # Completion can be disabled selectively to allow users to use non-standard completion.
365 # e.g.
366 # ENVSETUP_NO_COMPLETION=adb # -> disable adb completion
367 # ENVSETUP_NO_COMPLETION=adb:bit # -> disable adb and bit completion
Usta Shrestha1433fb32022-05-13 14:49:40 -0400368 local T=$(gettop)
Jim Tanga881a252018-06-19 16:34:41 +0800369 for f in ${completion_files[*]}; do
Usta Shrestha1433fb32022-05-13 14:49:40 -0400370 f="$T/$f"
MÃ¥rten Kongstadcb5c73f2022-05-04 14:08:12 +0000371 if [ ! -f "$f" ]; then
372 echo "Warning: completion file $f not found"
373 elif should_add_completion "$f"; then
Kenny Root52aa81c2011-07-15 11:07:06 -0700374 . $f
Elliott Hughesce18dd42018-04-03 13:49:48 -0700375 fi
376 done
Joe Onorato002a6c72016-10-20 16:39:49 -0700377
Anton Hanssonece9c482019-02-04 18:15:39 +0000378 if [ -z "$ZSH_VERSION" ]; then
379 # Doesn't work in zsh.
380 complete -o nospace -F _croot croot
Chris Parsonsa2972972022-08-31 15:04:38 -0400381 # TODO(b/244559459): Support b autocompletion for zsh
382 complete -F _bazel__complete -o nospace b
Anton Hanssonece9c482019-02-04 18:15:39 +0000383 fi
Jim Tanga881a252018-06-19 16:34:41 +0800384 complete -F _lunch lunch
Joe Onorato590ae9f2024-05-24 15:38:58 -0700385 complete -F _lunch_completion lunch2
Steven Moreland62054a42018-12-06 10:11:40 -0800386
Cole Faust24c36db2021-01-23 02:39:37 +0000387 complete -F _complete_android_module_names pathmod
dimitry73b84812018-12-11 18:06:00 +0100388 complete -F _complete_android_module_names gomod
Cole Faust24c36db2021-01-23 02:39:37 +0000389 complete -F _complete_android_module_names outmod
390 complete -F _complete_android_module_names installmod
dimitry73b84812018-12-11 18:06:00 +0100391 complete -F _complete_android_module_names m
Kenny Root52aa81c2011-07-15 11:07:06 -0700392}
393
Matt Alexanderd9c56562020-05-21 10:49:17 +0000394function add_lunch_combo()
395{
Dan Willemsen5436c7e2019-02-11 21:31:47 -0800396 if [ -n "$ZSH_VERSION" ]; then
397 echo -n "${funcfiletrace[1]}: "
398 else
399 echo -n "${BASH_SOURCE[1]}:${BASH_LINENO[0]}: "
400 fi
401 echo "add_lunch_combo is obsolete. Use COMMON_LUNCH_CHOICES in your AndroidProducts.mk instead."
The Android Open Source Projectdcc08f02008-12-17 18:03:49 -0800402}
403
Matt Alexanderd9c56562020-05-21 10:49:17 +0000404function print_lunch_menu()
405{
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700406 local uname=$(uname)
Roland Levillain23c46cf2020-03-31 16:11:05 +0100407 local choices
Joe Onorato0e68f702024-05-24 14:19:21 -0700408 choices=$(TARGET_BUILD_APPS= TARGET_PRODUCT= TARGET_RELEASE= TARGET_BUILD_VARIANT= _get_build_var_cached COMMON_LUNCH_CHOICES 2>/dev/null)
Roland Levillain23c46cf2020-03-31 16:11:05 +0100409 local ret=$?
410
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700411 echo
412 echo "You're building on" $uname
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700413 echo
Roland Levillain23c46cf2020-03-31 16:11:05 +0100414
Matt Alexanderd9c56562020-05-21 10:49:17 +0000415 if [ $ret -ne 0 ]
416 then
Roland Levillain23c46cf2020-03-31 16:11:05 +0100417 echo "Warning: Cannot display lunch menu."
418 echo
419 echo "Note: You can invoke lunch with an explicit target:"
420 echo
421 echo " usage: lunch [target]" >&2
422 echo
423 return
424 fi
425
Will Burr40401202022-02-07 12:12:01 +0000426 echo "Lunch menu .. Here are the common combinations:"
The Android Open Source Projectdcc08f02008-12-17 18:03:49 -0800427
428 local i=1
429 local choice
Dan Willemsen91763e92019-10-03 15:13:12 -0700430 for choice in $(echo $choices)
The Android Open Source Projectdcc08f02008-12-17 18:03:49 -0800431 do
432 echo " $i. $choice"
433 i=$(($i+1))
434 done
435
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700436 echo
437}
438
Joe Onorato590ae9f2024-05-24 15:38:58 -0700439function _lunch_meat()
440{
441 local product=$1
442 local release=$2
443 local variant=$3
444
Colin Cross88737132017-03-21 17:41:03 -0700445 TARGET_PRODUCT=$product \
Jeff Hamiltona02c7472023-05-08 03:13:29 +0000446 TARGET_RELEASE=$release \
Joe Onorato590ae9f2024-05-24 15:38:58 -0700447 TARGET_BUILD_VARIANT=$variant \
Colin Cross88737132017-03-21 17:41:03 -0700448 build_build_var_cache
Matt Alexanderd9c56562020-05-21 10:49:17 +0000449 if [ $? -ne 0 ]
450 then
cybojenix0dd2bfd2013-10-17 03:34:57 +0400451 # if we can't find the product, try to grab it from our github
452 T=$(gettop)
453 pushd $T > /dev/null
454 vendor/omni/build/tools/roomservice.py $product
455 popd > /dev/null
LuK133718ab35d2024-03-11 11:28:46 +0100456 check_product $product $release
cybojenix0dd2bfd2013-10-17 03:34:57 +0400457 else
458 T=$(gettop)
459 pushd $T > /dev/null
460 vendor/omni/build/tools/roomservice.py $product true
461 popd > /dev/null
462 fi
463 if [ $? -ne 0 ]
464 then
465 echo
466 echo "** Don't have a product spec for: '$product'"
467 echo "** Do you have the right repo manifest?"
468 product=
469 fi
470
471 if [ -z "$product" -o -z "$variant" ]
472 then
473 echo
Colin Cross88737132017-03-21 17:41:03 -0700474 return 1
475 fi
Joe Onorato0e68f702024-05-24 14:19:21 -0700476 export TARGET_PRODUCT=$(_get_build_var_cached TARGET_PRODUCT)
477 export TARGET_BUILD_VARIANT=$(_get_build_var_cached TARGET_BUILD_VARIANT)
Greg Kaiser5e2d3392023-10-27 14:15:48 -0600478 export TARGET_RELEASE=$release
479 # Note this is the string "release", not the value of the variable.
Jeff Browne33ba4c2011-07-11 22:11:46 -0700480 export TARGET_BUILD_TYPE=release
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700481
Michael Bestas539cda22021-05-06 16:44:13 +0300482 local prebuilt_kernel=$(_get_build_var_cached TARGET_PREBUILT_KERNEL)
483 if [ -z "$prebuilt_kernel" ]; then
484 export INLINE_KERNEL_BUILDING=true
485 else
486 unset INLINE_KERNEL_BUILDING
487 fi
488
Mark White2c807512023-10-25 17:27:07 +0000489 [[ -n "${ANDROID_QUIET_BUILD:-}" ]] || echo
490
491 set_stuff_for_environment
492 [[ -n "${ANDROID_QUIET_BUILD:-}" ]] || printconfig
493
Joe Onorato590ae9f2024-05-24 15:38:58 -0700494 if [[ -z "${ANDROID_QUIET_BUILD}" ]]; then
495 local spam_for_lunch=$(gettop)/build/make/tools/envsetup/spam_for_lunch
496 if [[ -x $spam_for_lunch ]]; then
497 $spam_for_lunch
498 fi
Will Burr40401202022-02-07 12:12:01 +0000499 fi
500
Ying Wang08800fd2016-03-03 20:57:21 -0800501 destroy_build_var_cache
Kousik Kumar41dacd12021-05-11 18:38:38 -0400502
503 if [[ -n "${CHECK_MU_CONFIG:-}" ]]; then
504 check_mu_config
505 fi
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700506}
507
Dan Willemsenaf2e1f82018-04-04 15:41:41 -0700508unset COMMON_LUNCH_CHOICES_CACHE
Jeff Davidson513d7a42010-08-02 10:00:44 -0700509# Tab completion for lunch.
Matt Alexanderd9c56562020-05-21 10:49:17 +0000510function _lunch()
511{
Jeff Davidson513d7a42010-08-02 10:00:44 -0700512 local cur prev opts
513 COMPREPLY=()
514 cur="${COMP_WORDS[COMP_CWORD]}"
515 prev="${COMP_WORDS[COMP_CWORD-1]}"
516
Dan Willemsenaf2e1f82018-04-04 15:41:41 -0700517 if [ -z "$COMMON_LUNCH_CHOICES_CACHE" ]; then
Joe Onorato0e68f702024-05-24 14:19:21 -0700518 COMMON_LUNCH_CHOICES_CACHE=$(TARGET_BUILD_APPS= _get_build_var_cached COMMON_LUNCH_CHOICES)
Dan Willemsenaf2e1f82018-04-04 15:41:41 -0700519 fi
520
521 COMPREPLY=( $(compgen -W "${COMMON_LUNCH_CHOICES_CACHE}" -- ${cur}) )
Jeff Davidson513d7a42010-08-02 10:00:44 -0700522 return 0
523}
Jeff Davidson513d7a42010-08-02 10:00:44 -0700524
Joe Onorato590ae9f2024-05-24 15:38:58 -0700525function _lunch_usage()
526{
527 (
528 echo "The lunch command selects the configuration to use for subsequent"
529 echo "Android builds."
530 echo
531 echo "Usage: lunch TARGET_PRODUCT [TARGET_RELEASE [TARGET_BUILD_VARIANT]]"
532 echo
533 echo " Choose the product, release and variant to use. If not"
534 echo " supplied, TARGET_RELEASE will be 'trunk_staging' and"
535 echo " TARGET_BUILD_VARIANT will be 'eng'"
536 echo
537 echo
538 echo "Usage: lunch TARGET_PRODUCT-TARGET_RELEASE-TARGET_BUILD_VARIANT"
539 echo
540 echo " Chose the product, release and variant to use. This"
541 echo " legacy format is maintained for compatibility."
542 echo
543 echo
544 echo "Note that the previous interactive menu and list of hard-coded"
545 echo "list of curated targets has been removed. If you would like the"
546 echo "list of products, release configs for a particular product, or"
Joe Onoratoa85234c2025-02-18 16:45:01 -0800547 echo "variants, run list_products list_releases or list_variants"
Joe Onorato590ae9f2024-05-24 15:38:58 -0700548 echo "respectively."
549 echo
550 ) 1>&2
551}
552
Joe Onoratoa85234c2025-02-18 16:45:01 -0800553function lunch()
Joe Onorato590ae9f2024-05-24 15:38:58 -0700554{
555 if [[ $# -eq 1 && $1 = "--help" ]]; then
556 _lunch_usage
557 return 0
558 fi
559 if [[ $# -eq 0 ]]; then
560 echo "No target specified. See lunch --help" 1>&2
561 return 1
562 fi
563 if [[ $# -gt 3 ]]; then
564 echo "Too many parameters given. See lunch --help" 1>&2
565 return 1
566 fi
567
568 local product release variant
569
570 # Handle the legacy format
571 local legacy=$(echo $1 | grep "-")
572 if [[ $# -eq 1 && -n $legacy ]]; then
573 IFS="-" read -r product release variant <<< "$1"
574 if [[ -z "$product" ]] || [[ -z "$release" ]] || [[ -z "$variant" ]]; then
575 echo "Invalid lunch combo: $1" 1>&2
576 echo "Valid combos must be of the form <product>-<release>-<variant> when using" 1>&2
577 echo "the legacy format. Run 'lunch --help' for usage." 1>&2
578 return 1
579 fi
580 fi
581
582 # Handle the new format.
583 if [[ -z $legacy ]]; then
584 product=$1
585 release=$2
586 if [[ -z $release ]]; then
587 release=trunk_staging
588 fi
589 variant=$3
590 if [[ -z $variant ]]; then
591 variant=eng
592 fi
593 fi
594
595 # Validate the selection and set all the environment stuff
596 _lunch_meat $product $release $variant
597}
598
599unset ANDROID_LUNCH_COMPLETION_PRODUCT_CACHE
600unset ANDROID_LUNCH_COMPLETION_CHOSEN_PRODUCT
601unset ANDROID_LUNCH_COMPLETION_RELEASE_CACHE
602# Tab completion for lunch.
603function _lunch_completion()
604{
605 # Available products
606 if [[ $COMP_CWORD -eq 1 ]] ; then
607 if [[ -z $ANDROID_LUNCH_COMPLETION_PRODUCT_CACHE ]]; then
608 ANDROID_LUNCH_COMPLETION_PRODUCT_CACHE=$(list_products)
609 fi
610 COMPREPLY=( $(compgen -W "${ANDROID_LUNCH_COMPLETION_PRODUCT_CACHE}" -- "${COMP_WORDS[COMP_CWORD]}") )
611 fi
612
613 # Available release configs
614 if [[ $COMP_CWORD -eq 2 ]] ; then
615 if [[ -z $ANDROID_LUNCH_COMPLETION_RELEASE_CACHE || $ANDROID_LUNCH_COMPLETION_CHOSEN_PRODUCT != ${COMP_WORDS[1]} ]] ; then
616 ANDROID_LUNCH_COMPLETION_RELEASE_CACHE=$(list_releases ${COMP_WORDS[1]})
617 ANDROID_LUNCH_COMPLETION_CHOSEN_PRODUCT=${COMP_WORDS[1]}
618 fi
619 COMPREPLY=( $(compgen -W "${ANDROID_LUNCH_COMPLETION_RELEASE_CACHE}" -- "${COMP_WORDS[COMP_CWORD]}") )
620 fi
621
622 # Available variants
623 if [[ $COMP_CWORD -eq 3 ]] ; then
624 COMPREPLY=(user userdebug eng)
625 fi
626
627 return 0
628}
629
630
Joe Onoratoda12daf2010-06-09 18:18:31 -0700631# Configures the build to build unbundled apps.
Doug Zongker0d8179e2014-04-16 11:34:34 -0700632# Run tapas with one or more app names (from LOCAL_PACKAGE_NAME)
Matt Alexanderd9c56562020-05-21 10:49:17 +0000633function tapas()
634{
Jeff Gaston9fb05d82017-08-21 18:27:00 -0700635 local showHelp="$(echo $* | xargs -n 1 echo | \grep -E '^(help)$' | xargs)"
Elliott Hughesf71c05a2020-03-06 16:46:59 -0800636 local arch="$(echo $* | xargs -n 1 echo | \grep -E '^(arm|x86|arm64|x86_64)$' | xargs)"
Greg Kaiser83ed1592023-10-26 18:37:40 +0000637 # TODO(b/307975293): Expand tapas to take release arguments (and update hmm() usage).
638 local release="trunk_staging"
Doug Zongker0d8179e2014-04-16 11:34:34 -0700639 local variant="$(echo $* | xargs -n 1 echo | \grep -E '^(user|userdebug|eng)$' | xargs)"
Jeff Hamilton5069bd62014-09-04 21:28:00 -0700640 local density="$(echo $* | xargs -n 1 echo | \grep -E '^(ldpi|mdpi|tvdpi|hdpi|xhdpi|xxhdpi|xxxhdpi|alldpi)$' | xargs)"
Colin Cross7f49a672022-01-27 18:15:53 -0800641 local keys="$(echo $* | xargs -n 1 echo | \grep -E '^(devkeys)$' | xargs)"
642 local apps="$(echo $* | xargs -n 1 echo | \grep -E -v '^(user|userdebug|eng|arm|x86|arm64|x86_64|ldpi|mdpi|tvdpi|hdpi|xhdpi|xxhdpi|xxxhdpi|alldpi|devkeys)$' | xargs)"
643
Joe Onoratoda12daf2010-06-09 18:18:31 -0700644
Jeff Gaston9fb05d82017-08-21 18:27:00 -0700645 if [ "$showHelp" != "" ]; then
646 $(gettop)/build/make/tapasHelp.sh
647 return
648 fi
649
Ying Wang67f02922012-08-22 10:25:20 -0700650 if [ $(echo $arch | wc -w) -gt 1 ]; then
651 echo "tapas: Error: Multiple build archs supplied: $arch"
652 return
653 fi
Greg Kaiser83ed1592023-10-26 18:37:40 +0000654 if [ $(echo $release | wc -w) -gt 1 ]; then
655 echo "tapas: Error: Multiple build releases supplied: $release"
656 return
657 fi
Joe Onoratoda12daf2010-06-09 18:18:31 -0700658 if [ $(echo $variant | wc -w) -gt 1 ]; then
659 echo "tapas: Error: Multiple build variants supplied: $variant"
660 return
661 fi
Jeff Hamilton5069bd62014-09-04 21:28:00 -0700662 if [ $(echo $density | wc -w) -gt 1 ]; then
663 echo "tapas: Error: Multiple densities supplied: $density"
664 return
665 fi
Colin Cross7f49a672022-01-27 18:15:53 -0800666 if [ $(echo $keys | wc -w) -gt 1 ]; then
667 echo "tapas: Error: Multiple keys supplied: $keys"
668 return
669 fi
Ying Wang67f02922012-08-22 10:25:20 -0700670
Ying Wang0a76df52015-06-08 11:57:26 -0700671 local product=aosp_arm
Ying Wang67f02922012-08-22 10:25:20 -0700672 case $arch in
Matt Alexanderd9c56562020-05-21 10:49:17 +0000673 x86) product=aosp_x86;;
674 arm64) product=aosp_arm64;;
675 x86_64) product=aosp_x86_64;;
Ying Wang67f02922012-08-22 10:25:20 -0700676 esac
Colin Cross7f49a672022-01-27 18:15:53 -0800677 if [ -n "$keys" ]; then
678 product=${product/aosp_/aosp_${keys}_}
679 fi;
680
Joe Onoratoda12daf2010-06-09 18:18:31 -0700681 if [ -z "$variant" ]; then
682 variant=eng
683 fi
Ying Wangc048c9b2010-06-24 15:08:33 -0700684 if [ -z "$apps" ]; then
685 apps=all
686 fi
Justin Morey29d225c2014-11-04 13:35:51 -0600687 if [ -z "$density" ]; then
688 density=alldpi
689 fi
Joe Onoratoda12daf2010-06-09 18:18:31 -0700690
Ying Wang67f02922012-08-22 10:25:20 -0700691 export TARGET_PRODUCT=$product
Greg Kaiser83ed1592023-10-26 18:37:40 +0000692 export TARGET_RELEASE=$release
Joe Onoratoda12daf2010-06-09 18:18:31 -0700693 export TARGET_BUILD_VARIANT=$variant
Jeff Hamilton5069bd62014-09-04 21:28:00 -0700694 export TARGET_BUILD_DENSITY=$density
Joe Onoratoda12daf2010-06-09 18:18:31 -0700695 export TARGET_BUILD_TYPE=release
696 export TARGET_BUILD_APPS=$apps
697
Ying Wang08800fd2016-03-03 20:57:21 -0800698 build_build_var_cache
Joe Onoratoda12daf2010-06-09 18:18:31 -0700699 set_stuff_for_environment
700 printconfig
Ying Wang08800fd2016-03-03 20:57:21 -0800701 destroy_build_var_cache
Joe Onoratoda12daf2010-06-09 18:18:31 -0700702}
703
Martin Stjernholmf692c752021-04-12 00:01:10 +0100704# Configures the build to build unbundled Android modules (APEXes).
705# Run banchan with one or more module names (from apex{} modules).
706function banchan()
707{
708 local showHelp="$(echo $* | xargs -n 1 echo | \grep -E '^(help)$' | xargs)"
Ulya Trafimovich08c381b2023-06-12 15:33:09 +0100709 local product="$(echo $* | xargs -n 1 echo | \grep -E '^(.*_)?(arm|x86|arm64|riscv64|x86_64|arm64only|x86_64only)$' | xargs)"
Greg Kaiserd35095e2023-10-27 16:04:30 -0600710 # TODO: Expand banchan to take release arguments (and update hmm() usage).
711 local release="trunk_staging"
Martin Stjernholmf692c752021-04-12 00:01:10 +0100712 local variant="$(echo $* | xargs -n 1 echo | \grep -E '^(user|userdebug|eng)$' | xargs)"
Ulya Trafimovich08c381b2023-06-12 15:33:09 +0100713 local apps="$(echo $* | xargs -n 1 echo | \grep -E -v '^(user|userdebug|eng|(.*_)?(arm|x86|arm64|riscv64|x86_64))$' | xargs)"
Martin Stjernholmf692c752021-04-12 00:01:10 +0100714
715 if [ "$showHelp" != "" ]; then
716 $(gettop)/build/make/banchanHelp.sh
717 return
718 fi
719
Martin Stjernholm2b8d9232021-04-16 20:45:03 +0100720 if [ -z "$product" ]; then
Anton Hansson0328e322022-05-24 15:47:40 +0000721 product=arm64
Martin Stjernholm2b8d9232021-04-16 20:45:03 +0100722 elif [ $(echo $product | wc -w) -gt 1 ]; then
723 echo "banchan: Error: Multiple build archs or products supplied: $products"
Martin Stjernholmf692c752021-04-12 00:01:10 +0100724 return
725 fi
Greg Kaiserd35095e2023-10-27 16:04:30 -0600726 if [ $(echo $release | wc -w) -gt 1 ]; then
727 echo "banchan: Error: Multiple build releases supplied: $release"
728 return
729 fi
Martin Stjernholmf692c752021-04-12 00:01:10 +0100730 if [ $(echo $variant | wc -w) -gt 1 ]; then
731 echo "banchan: Error: Multiple build variants supplied: $variant"
732 return
733 fi
734 if [ -z "$apps" ]; then
735 echo "banchan: Error: No modules supplied"
736 return
737 fi
738
Martin Stjernholm2b8d9232021-04-16 20:45:03 +0100739 case $product in
740 arm) product=module_arm;;
Martin Stjernholmf692c752021-04-12 00:01:10 +0100741 x86) product=module_x86;;
742 arm64) product=module_arm64;;
Ulya Trafimovich08c381b2023-06-12 15:33:09 +0100743 riscv64) product=module_riscv64;;
Martin Stjernholmf692c752021-04-12 00:01:10 +0100744 x86_64) product=module_x86_64;;
Anton Hansson90ac61c2022-09-06 14:36:00 +0000745 arm64only) product=module_arm64only;;
746 x86_64only) product=module_x86_64only;;
Martin Stjernholmf692c752021-04-12 00:01:10 +0100747 esac
748 if [ -z "$variant" ]; then
749 variant=eng
750 fi
751
752 export TARGET_PRODUCT=$product
Greg Kaiserd35095e2023-10-27 16:04:30 -0600753 export TARGET_RELEASE=$release
Martin Stjernholmf692c752021-04-12 00:01:10 +0100754 export TARGET_BUILD_VARIANT=$variant
755 export TARGET_BUILD_DENSITY=alldpi
756 export TARGET_BUILD_TYPE=release
757
758 # This setup currently uses TARGET_BUILD_APPS just like tapas, but the use
759 # case is different and it may diverge in the future.
760 export TARGET_BUILD_APPS=$apps
761
762 build_build_var_cache
763 set_stuff_for_environment
764 printconfig
765 destroy_build_var_cache
766}
767
Matt Alexanderd9c56562020-05-21 10:49:17 +0000768function croot()
769{
Christopher Ferris55257d22017-03-23 11:08:58 -0700770 local T=$(gettop)
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700771 if [ "$T" ]; then
Marie Janssen32ec50a2016-04-21 16:53:39 -0700772 if [ "$1" ]; then
773 \cd $(gettop)/$1
774 else
775 \cd $(gettop)
776 fi
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700777 else
778 echo "Couldn't locate the top of the tree. Try setting TOP."
779 fi
780}
781
Matt Alexanderd9c56562020-05-21 10:49:17 +0000782function _croot()
783{
Anton Hanssonece9c482019-02-04 18:15:39 +0000784 local T=$(gettop)
785 if [ "$T" ]; then
786 local cur="${COMP_WORDS[COMP_CWORD]}"
787 k=0
788 for c in $(compgen -d ${T}/${cur}); do
789 COMPREPLY[k++]=${c#${T}/}/
790 done
791 fi
792}
793
Matt Alexanderd9c56562020-05-21 10:49:17 +0000794function cproj()
795{
Colin Cross6cdc5d22017-10-20 11:37:33 -0700796 local TOPFILE=build/make/core/envsetup.mk
Joe Onorato2a5d4d82009-07-30 10:23:21 -0700797 local HERE=$PWD
Christopher Ferris55257d22017-03-23 11:08:58 -0700798 local T=
Joe Onorato2a5d4d82009-07-30 10:23:21 -0700799 while [ \( ! \( -f $TOPFILE \) \) -a \( $PWD != "/" \) ]; do
800 T=$PWD
801 if [ -f "$T/Android.mk" ]; then
Ying Wang9cd17642012-12-13 10:52:07 -0800802 \cd $T
Joe Onorato2a5d4d82009-07-30 10:23:21 -0700803 return
804 fi
Ying Wang9cd17642012-12-13 10:52:07 -0800805 \cd ..
Joe Onorato2a5d4d82009-07-30 10:23:21 -0700806 done
Ying Wang9cd17642012-12-13 10:52:07 -0800807 \cd $HERE
Joe Onorato2a5d4d82009-07-30 10:23:21 -0700808 echo "can't find Android.mk"
809}
810
Elliott Hughes86e99172024-03-21 16:55:08 +0000811# Ensure that we're always using the adb in the tree. This works around the fact
812# that bash caches $PATH lookups, so if you use adb before lunching/building the
813# one in your tree, you'll continue to get /usr/bin/adb or whatever even after
814# you have the one from your current tree on your path. Historically this would
815# cause confusion because glinux had adb in /usr/bin/ by default, though that
816# doesn't appear to be the case on my rodete hosts; it is however still the case
817# that my Mac has /usr/local/bin/adb installed by default and on the default
818# path.
Shaju Mathew21439002023-07-10 00:53:22 +0000819function adb() {
Elliott Hughes57c47b72024-03-22 15:46:59 +0000820 # We need `command which` because zsh has a built-in `which` that's more
821 # like `type`.
822 local ADB=$(command which adb)
Elliott Hughes7e7ff752024-03-20 17:23:40 -0700823 if [ -z "$ADB" ]; then
824 echo "Command adb not found; try lunch (and building) first?"
825 return 1
826 fi
Zhuoyao Zhang60dd9dd2024-04-19 00:07:59 +0000827 run_tool_with_logging "ADB" $ADB "${@}"
Shaju Mathew21439002023-07-10 00:53:22 +0000828}
829
Zhuoyao Zhangf02aadf2024-06-10 18:28:25 +0000830function fastboot() {
831 local FASTBOOT=$(command which fastboot)
832 if [ -z "$FASTBOOT" ]; then
833 echo "Command fastboot not found; try lunch (and building) first?"
834 return 1
835 fi
836 # Support tool event logging for fastboot command.
837 run_tool_with_logging "FASTBOOT" $FASTBOOT "${@}"
838}
839
The Android Open Source Projectdcc08f02008-12-17 18:03:49 -0800840# communicate with a running device or emulator, set up necessary state,
841# and run the hat command.
Matt Alexanderd9c56562020-05-21 10:49:17 +0000842function runhat()
843{
The Android Open Source Projectdcc08f02008-12-17 18:03:49 -0800844 # process standard adb options
845 local adbTarget=""
Matt Alexanderd9c56562020-05-21 10:49:17 +0000846 if [ "$1" = "-d" -o "$1" = "-e" ]; then
The Android Open Source Projectdcc08f02008-12-17 18:03:49 -0800847 adbTarget=$1
848 shift 1
Matt Alexanderd9c56562020-05-21 10:49:17 +0000849 elif [ "$1" = "-s" ]; then
The Android Open Source Projectdcc08f02008-12-17 18:03:49 -0800850 adbTarget="$1 $2"
851 shift 2
852 fi
853 local adbOptions=${adbTarget}
Matt Alexanderd9c56562020-05-21 10:49:17 +0000854 #echo adbOptions = ${adbOptions}
The Android Open Source Projectdcc08f02008-12-17 18:03:49 -0800855
856 # runhat options
857 local targetPid=$1
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700858
Matt Alexanderd9c56562020-05-21 10:49:17 +0000859 if [ "$targetPid" = "" ]; then
Andy McFaddenb6289852010-07-12 08:00:19 -0700860 echo "Usage: runhat [ -d | -e | -s serial ] target-pid"
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700861 return
862 fi
863
The Android Open Source Projectdcc08f02008-12-17 18:03:49 -0800864 # confirm hat is available
865 if [ -z $(which hat) ]; then
866 echo "hat is not available in this configuration."
867 return
868 fi
869
Andy McFaddenb6289852010-07-12 08:00:19 -0700870 # issue "am" command to cause the hprof dump
Nick Kralevich9948b1e2014-07-18 15:45:38 -0700871 local devFile=/data/local/tmp/hprof-$targetPid
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700872 echo "Poking $targetPid and waiting for data..."
Dianne Hackborn6b9549f2012-09-26 15:00:59 -0700873 echo "Storing data at $devFile"
Andy McFaddenb6289852010-07-12 08:00:19 -0700874 adb ${adbOptions} shell am dumpheap $targetPid $devFile
The Android Open Source Project88b60792009-03-03 19:28:42 -0800875 echo "Press enter when logcat shows \"hprof: heap dump completed\""
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700876 echo -n "> "
877 read
878
The Android Open Source Project88b60792009-03-03 19:28:42 -0800879 local localFile=/tmp/$$-hprof
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700880
The Android Open Source Project88b60792009-03-03 19:28:42 -0800881 echo "Retrieving file $devFile..."
882 adb ${adbOptions} pull $devFile $localFile
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700883
The Android Open Source Project88b60792009-03-03 19:28:42 -0800884 adb ${adbOptions} shell rm $devFile
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700885
The Android Open Source Project88b60792009-03-03 19:28:42 -0800886 echo "Running hat on $localFile"
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700887 echo "View the output by pointing your browser at http://localhost:7000/"
888 echo ""
Dianne Hackborn6e4e1bb2011-11-10 15:19:51 -0800889 hat -JXmx512m $localFile
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700890}
891
The Android Open Source Project88b60792009-03-03 19:28:42 -0800892function godir () {
893 if [[ -z "$1" ]]; then
894 echo "Usage: godir <regex>"
895 return
896 fi
Christopher Ferris55257d22017-03-23 11:08:58 -0700897 local T=$(gettop)
898 local FILELIST
Matt Alexanderd9c56562020-05-21 10:49:17 +0000899 if [ ! "$OUT_DIR" = "" ]; then
Brian Carlstromf2257422015-09-30 20:28:54 -0700900 mkdir -p $OUT_DIR
901 FILELIST=$OUT_DIR/filelist
902 else
903 FILELIST=$T/filelist
904 fi
905 if [[ ! -f $FILELIST ]]; then
The Android Open Source Project88b60792009-03-03 19:28:42 -0800906 echo -n "Creating index..."
Brian Carlstromf2257422015-09-30 20:28:54 -0700907 (\cd $T; find . -wholename ./out -prune -o -wholename ./.repo -prune -o -type f > $FILELIST)
The Android Open Source Project88b60792009-03-03 19:28:42 -0800908 echo " Done"
909 echo ""
910 fi
911 local lines
Brian Carlstromf2257422015-09-30 20:28:54 -0700912 lines=($(\grep "$1" $FILELIST | sed -e 's/\/[^/]*$//' | sort | uniq))
Matt Alexanderd9c56562020-05-21 10:49:17 +0000913 if [[ ${#lines[@]} = 0 ]]; then
The Android Open Source Project88b60792009-03-03 19:28:42 -0800914 echo "Not found"
915 return
916 fi
917 local pathname
918 local choice
919 if [[ ${#lines[@]} > 1 ]]; then
920 while [[ -z "$pathname" ]]; do
921 local index=1
922 local line
923 for line in ${lines[@]}; do
924 printf "%6s %s\n" "[$index]" $line
Doug Zongker29034982011-04-22 08:16:56 -0700925 index=$(($index + 1))
The Android Open Source Project88b60792009-03-03 19:28:42 -0800926 done
927 echo
928 echo -n "Select one: "
929 unset choice
930 read choice
931 if [[ $choice -gt ${#lines[@]} || $choice -lt 1 ]]; then
932 echo "Invalid choice"
933 continue
934 fi
Guillaume Chelfice000fd2019-10-03 12:02:46 +0200935 pathname=${lines[@]:$(($choice-1)):1}
The Android Open Source Project88b60792009-03-03 19:28:42 -0800936 done
937 else
Guillaume Chelfice000fd2019-10-03 12:02:46 +0200938 pathname=${lines[@]:0:1}
The Android Open Source Project88b60792009-03-03 19:28:42 -0800939 fi
Ying Wang9cd17642012-12-13 10:52:07 -0800940 \cd $T/$pathname
The Android Open Source Project88b60792009-03-03 19:28:42 -0800941}
942
Rett Berg78d1c932019-01-24 14:34:23 -0800943# Go to a specific module in the android tree, as cached in module-info.json. If any build change
944# is made, and it should be reflected in the output, you should run 'refreshmod' first.
Joe Onorato6b543832024-05-23 12:26:50 -0700945# Note: This function is in envsetup because changing the directory needs to happen in the current
946# shell. All other functions that use module-info.json should be in build/soong/bin.
Rett Berg78d1c932019-01-24 14:34:23 -0800947function gomod() {
948 if [[ $# -ne 1 ]]; then
949 echo "usage: gomod <module>" >&2
950 return 1
951 fi
952
953 local path="$(pathmod $@)"
954 if [ -z "$path" ]; then
955 return 1
956 fi
957 cd $path
958}
959
dimitry73b84812018-12-11 18:06:00 +0100960function _complete_android_module_names() {
Steven Moreland62054a42018-12-06 10:11:40 -0800961 local word=${COMP_WORDS[COMP_CWORD]}
Cole Faust5d825b72022-10-26 18:16:44 -0700962 COMPREPLY=( $(allmod | grep -E "^$word") )
Steven Moreland62054a42018-12-06 10:11:40 -0800963}
964
Matt Alexanderd9c56562020-05-21 10:49:17 +0000965function get_make_command()
966{
Dan Willemsend41ec5a2017-07-12 16:14:50 -0700967 # If we're in the top of an Android tree, use soong_ui.bash instead of make
968 if [ -f build/soong/soong_ui.bash ]; then
Dan Willemsene9842242017-07-28 13:00:13 -0700969 # Always use the real make if -C is passed in
970 for arg in "$@"; do
971 if [[ $arg == -C* ]]; then
972 echo command make
973 return
974 fi
975 done
Dan Willemsend41ec5a2017-07-12 16:14:50 -0700976 echo build/soong/soong_ui.bash --make-mode
977 else
978 echo command make
979 fi
Ying Wanged21d4c2014-08-24 22:14:19 -0700980}
981
Matt Alexanderd9c56562020-05-21 10:49:17 +0000982function make()
983{
Dan Willemsene9842242017-07-28 13:00:13 -0700984 _wrap_build $(get_make_command "$@") "$@"
Dan Willemsend41ec5a2017-07-12 16:14:50 -0700985}
986
Jim Tanga881a252018-06-19 16:34:41 +0800987# Zsh needs bashcompinit called to support bash-style completion.
Patrik Fimmldf248e62018-10-15 18:15:12 +0200988function enable_zsh_completion() {
989 # Don't override user's options if bash-style completion is already enabled.
990 if ! declare -f complete >/dev/null; then
991 autoload -U compinit && compinit
992 autoload -U bashcompinit && bashcompinit
993 fi
Jim Tanga881a252018-06-19 16:34:41 +0800994}
995
996function validate_current_shell() {
997 local current_sh="$(ps -o command -p $$)"
998 case "$current_sh" in
Raphael Moll70a86b02011-06-20 16:03:14 -0700999 *bash*)
Jim Tanga881a252018-06-19 16:34:41 +08001000 function check_type() { type -t "$1"; }
Raphael Moll70a86b02011-06-20 16:03:14 -07001001 ;;
Jim Tanga881a252018-06-19 16:34:41 +08001002 *zsh*)
1003 function check_type() { type "$1"; }
Matt Alexanderd9c56562020-05-21 10:49:17 +00001004 enable_zsh_completion ;;
Raphael Moll70a86b02011-06-20 16:03:14 -07001005 *)
Jim Tanga881a252018-06-19 16:34:41 +08001006 echo -e "WARNING: Only bash and zsh are supported.\nUse of other shell would lead to erroneous results."
Raphael Moll70a86b02011-06-20 16:03:14 -07001007 ;;
1008 esac
Jim Tanga881a252018-06-19 16:34:41 +08001009}
The Android Open Source Projectdcc08f02008-12-17 18:03:49 -08001010
1011# Execute the contents of any vendorsetup.sh files we can find.
Dan Willemsend855a722019-02-12 15:52:36 -08001012# Unless we find an allowed-vendorsetup_sh-files file, in which case we'll only
1013# load those.
1014#
1015# This allows loading only approved vendorsetup.sh files
Jim Tanga881a252018-06-19 16:34:41 +08001016function source_vendorsetup() {
Jim Tangc4dba1d2019-07-25 16:54:27 +08001017 unset VENDOR_PYTHONPATH
Patrice Arrudaaa4b8242020-10-12 21:29:14 +00001018 local T="$(gettop)"
Dan Willemsend855a722019-02-12 15:52:36 -08001019 allowed=
Patrice Arrudaaa4b8242020-10-12 21:29:14 +00001020 for f in $(cd "$T" && find -L device vendor product -maxdepth 4 -name 'allowed-vendorsetup_sh-files' 2>/dev/null | sort); do
Dan Willemsend855a722019-02-12 15:52:36 -08001021 if [ -n "$allowed" ]; then
1022 echo "More than one 'allowed_vendorsetup_sh-files' file found, not including any vendorsetup.sh files:"
1023 echo " $allowed"
1024 echo " $f"
1025 return
1026 fi
Patrice Arrudaaa4b8242020-10-12 21:29:14 +00001027 allowed="$T/$f"
Dan Willemsend855a722019-02-12 15:52:36 -08001028 done
1029
1030 allowed_files=
1031 [ -n "$allowed" ] && allowed_files=$(cat "$allowed")
Jim Tanga881a252018-06-19 16:34:41 +08001032 for dir in device vendor product; do
Patrice Arrudaaa4b8242020-10-12 21:29:14 +00001033 for f in $(cd "$T" && test -d $dir && \
Jim Tanga881a252018-06-19 16:34:41 +08001034 find -L $dir -maxdepth 4 -name 'vendorsetup.sh' 2>/dev/null | sort); do
Dan Willemsend855a722019-02-12 15:52:36 -08001035
1036 if [[ -z "$allowed" || "$allowed_files" =~ $f ]]; then
Patrice Arrudaaa4b8242020-10-12 21:29:14 +00001037 echo "including $f"; . "$T/$f"
Dan Willemsend855a722019-02-12 15:52:36 -08001038 else
1039 echo "ignoring $f, not in $allowed"
1040 fi
Jim Tanga881a252018-06-19 16:34:41 +08001041 done
1042 done
Kousik Kumarec5416c2023-09-14 17:11:45 +00001043
Sam Lewis2404c4a2024-09-23 20:06:02 +00001044 setup_cog_env_if_needed
Jim Tanga881a252018-06-19 16:34:41 +08001045}
Kenny Root52aa81c2011-07-15 11:07:06 -07001046
Dan Albertbab814f2020-08-26 15:34:53 -07001047function showcommands() {
1048 local T=$(gettop)
1049 if [[ -z "$TARGET_PRODUCT" ]]; then
1050 >&2 echo "TARGET_PRODUCT not set. Run lunch."
1051 return
1052 fi
1053 case $(uname -s) in
1054 Darwin)
1055 PREBUILT_NAME=darwin-x86
1056 ;;
1057 Linux)
1058 PREBUILT_NAME=linux-x86
1059 ;;
1060 *)
1061 >&2 echo Unknown host $(uname -s)
1062 return
1063 ;;
1064 esac
Joe Onorato0e68f702024-05-24 14:19:21 -07001065 OUT_DIR="$(_get_abs_build_var_cached OUT_DIR)"
Dan Albertbab814f2020-08-26 15:34:53 -07001066 if [[ "$1" == "--regenerate" ]]; then
1067 shift 1
1068 NINJA_ARGS="-t commands $@" m
1069 else
1070 (cd $T && prebuilts/build-tools/$PREBUILT_NAME/bin/ninja \
1071 -f $OUT_DIR/combined-${TARGET_PRODUCT}.ninja \
1072 -t commands "$@")
1073 fi
1074}
1075
Joe Onorato1b9ab292024-05-17 12:16:43 -07001076# These functions used to be here but are now standalone scripts
1077# in build/soong/bin. Unset these for the time being so the real
1078# script is picked up.
Joe Onorato23124752024-05-14 15:06:48 -07001079# TODO: Remove this some time after a suitable delay (maybe 2025?)
Joe Onorato6b543832024-05-23 12:26:50 -07001080unset allmod
Joe Onorato23124752024-05-14 15:06:48 -07001081unset aninja
Joe Onorato1b9ab292024-05-17 12:16:43 -07001082unset cgrep
Joe Onorato3acb3082024-05-24 14:14:46 -07001083unset core
1084unset coredump_enable
1085unset coredump_setup
Joe Onorato6b543832024-05-23 12:26:50 -07001086unset dirmods
Joe Onorato0e68f702024-05-24 14:19:21 -07001087unset get_build_var
1088unset get_abs_build_var
Joe Onorato3acb3082024-05-24 14:14:46 -07001089unset getlastscreenshot
1090unset getprebuilt
1091unset getscreenshotpath
1092unset getsdcardpath
1093unset gettargetarch
Joe Onorato1b9ab292024-05-17 12:16:43 -07001094unset ggrep
1095unset gogrep
Joe Onorato3acb3082024-05-24 14:14:46 -07001096unset hmm
Joe Onorato6b543832024-05-23 12:26:50 -07001097unset installmod
Joe Onorato3acb3082024-05-24 14:14:46 -07001098unset is64bit
1099unset isviewserverstarted
Joe Onorato1b9ab292024-05-17 12:16:43 -07001100unset jgrep
1101unset jsongrep
Joe Onorato3acb3082024-05-24 14:14:46 -07001102unset key_back
1103unset key_home
1104unset key_menu
Joe Onorato1b9ab292024-05-17 12:16:43 -07001105unset ktgrep
Joe Onorato6b543832024-05-23 12:26:50 -07001106unset m
Joe Onorato1b9ab292024-05-17 12:16:43 -07001107unset mangrep
1108unset mgrep
Joe Onorato6b543832024-05-23 12:26:50 -07001109unset mm
1110unset mma
1111unset mmm
1112unset mmma
1113unset outmod
1114unset overrideflags
Joe Onorato1b9ab292024-05-17 12:16:43 -07001115unset owngrep
Joe Onorato6b543832024-05-23 12:26:50 -07001116unset pathmod
Joe Onoratoff277c52024-05-23 12:52:07 -07001117unset pez
Joe Onorato1b9ab292024-05-17 12:16:43 -07001118unset pygrep
Joe Onorato6b543832024-05-23 12:26:50 -07001119unset qpid
Joe Onorato1b9ab292024-05-17 12:16:43 -07001120unset rcgrep
Joe Onorato6b543832024-05-23 12:26:50 -07001121unset refreshmod
Joe Onorato1b9ab292024-05-17 12:16:43 -07001122unset resgrep
1123unset rsgrep
Zhuoyao Zhang1698d492024-05-21 23:55:27 +00001124unset run_tool_with_logging
Joe Onorato1b9ab292024-05-17 12:16:43 -07001125unset sepgrep
1126unset sgrep
Joe Onorato3acb3082024-05-24 14:14:46 -07001127unset startviewserver
1128unset stopviewserver
1129unset systemstack
Joe Onorato6b543832024-05-23 12:26:50 -07001130unset syswrite
Joe Onorato1b9ab292024-05-17 12:16:43 -07001131unset tomlgrep
1132unset treegrep
Cole Faust45844ab2022-08-30 13:59:07 -07001133
Colin Cross71319722023-10-24 10:58:46 -07001134
Jim Tanga881a252018-06-19 16:34:41 +08001135validate_current_shell
Joe Onorato7c3a77f2022-12-05 13:05:14 -08001136set_global_paths
Jim Tanga881a252018-06-19 16:34:41 +08001137source_vendorsetup
Kenny Root52aa81c2011-07-15 11:07:06 -07001138addcompletions
Joe Onorato7c3a77f2022-12-05 13:05:14 -08001139
Chirayu Desaida3345a2013-03-19 17:50:37 +05301140export ANDROID_BUILD_TOP=$(gettop)
Michael Bestas971da5d2016-08-26 00:37:02 +03001141
1142. $ANDROID_BUILD_TOP/vendor/omni/build/envsetup.sh