blob: c04031186e0220c4f218e04ae065ac86a5a63a1b [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.
Joe Onorato0e68f702024-05-24 14:19:21 -070056 cached_vars=(`cat $T/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 | 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
The Android Open Source Projectdcc08f02008-12-17 18:03:49 -0800328 export ANDROID_BUILD_TOP=$(gettop)
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700329}
330
Matt Alexanderd9c56562020-05-21 10:49:17 +0000331function set_sequence_number()
332{
Colin Cross88737132017-03-21 17:41:03 -0700333 export BUILD_ENV_SEQUENCE_NUMBER=13
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700334}
335
Makoto Onukida971062018-06-18 10:15:19 -0700336# Takes a command name, and check if it's in ENVSETUP_NO_COMPLETION or not.
337function should_add_completion() {
Jim Tanga881a252018-06-19 16:34:41 +0800338 local cmd="$(basename $1| sed 's/_completion//' |sed 's/\.\(.*\)*sh$//')"
Makoto Onukida971062018-06-18 10:15:19 -0700339 case :"$ENVSETUP_NO_COMPLETION": in
Jim Tanga881a252018-06-19 16:34:41 +0800340 *:"$cmd":*)
341 return 1
342 ;;
Makoto Onukida971062018-06-18 10:15:19 -0700343 esac
344 return 0
345}
346
Matt Alexanderd9c56562020-05-21 10:49:17 +0000347function addcompletions()
348{
Ben Taitelbaum8c2c9cf2020-09-22 16:45:05 -0700349 local f=
Kenny Root52aa81c2011-07-15 11:07:06 -0700350
Jim Tanga881a252018-06-19 16:34:41 +0800351 # Keep us from trying to run in something that's neither bash nor zsh.
352 if [ -z "$BASH_VERSION" -a -z "$ZSH_VERSION" ]; then
Kenny Root52aa81c2011-07-15 11:07:06 -0700353 return
354 fi
355
356 # Keep us from trying to run in bash that's too old.
Jim Tanga881a252018-06-19 16:34:41 +0800357 if [ -n "$BASH_VERSION" -a ${BASH_VERSINFO[0]} -lt 3 ]; then
Kenny Root52aa81c2011-07-15 11:07:06 -0700358 return
359 fi
360
Jim Tanga881a252018-06-19 16:34:41 +0800361 local completion_files=(
MÃ¥rten Kongstadcb5c73f2022-05-04 14:08:12 +0000362 packages/modules/adb/adb.bash
Jim Tanga881a252018-06-19 16:34:41 +0800363 system/core/fastboot/fastboot.bash
Jim Tangb3fda302018-12-22 10:24:55 +0800364 tools/asuite/asuite.sh
Jim Tanga881a252018-06-19 16:34:41 +0800365 )
Makoto Onukida971062018-06-18 10:15:19 -0700366 # Completion can be disabled selectively to allow users to use non-standard completion.
367 # e.g.
368 # ENVSETUP_NO_COMPLETION=adb # -> disable adb completion
369 # ENVSETUP_NO_COMPLETION=adb:bit # -> disable adb and bit completion
Usta Shrestha1433fb32022-05-13 14:49:40 -0400370 local T=$(gettop)
Jim Tanga881a252018-06-19 16:34:41 +0800371 for f in ${completion_files[*]}; do
Usta Shrestha1433fb32022-05-13 14:49:40 -0400372 f="$T/$f"
MÃ¥rten Kongstadcb5c73f2022-05-04 14:08:12 +0000373 if [ ! -f "$f" ]; then
374 echo "Warning: completion file $f not found"
375 elif should_add_completion "$f"; then
Kenny Root52aa81c2011-07-15 11:07:06 -0700376 . $f
Elliott Hughesce18dd42018-04-03 13:49:48 -0700377 fi
378 done
Joe Onorato002a6c72016-10-20 16:39:49 -0700379
Anton Hanssonece9c482019-02-04 18:15:39 +0000380 if [ -z "$ZSH_VERSION" ]; then
381 # Doesn't work in zsh.
382 complete -o nospace -F _croot croot
Chris Parsonsa2972972022-08-31 15:04:38 -0400383 # TODO(b/244559459): Support b autocompletion for zsh
384 complete -F _bazel__complete -o nospace b
Anton Hanssonece9c482019-02-04 18:15:39 +0000385 fi
Jim Tanga881a252018-06-19 16:34:41 +0800386 complete -F _lunch lunch
Joe Onorato590ae9f2024-05-24 15:38:58 -0700387 complete -F _lunch_completion lunch2
Steven Moreland62054a42018-12-06 10:11:40 -0800388
Cole Faust24c36db2021-01-23 02:39:37 +0000389 complete -F _complete_android_module_names pathmod
dimitry73b84812018-12-11 18:06:00 +0100390 complete -F _complete_android_module_names gomod
Cole Faust24c36db2021-01-23 02:39:37 +0000391 complete -F _complete_android_module_names outmod
392 complete -F _complete_android_module_names installmod
dimitry73b84812018-12-11 18:06:00 +0100393 complete -F _complete_android_module_names m
Kenny Root52aa81c2011-07-15 11:07:06 -0700394}
395
Matt Alexanderd9c56562020-05-21 10:49:17 +0000396function add_lunch_combo()
397{
Dan Willemsen5436c7e2019-02-11 21:31:47 -0800398 if [ -n "$ZSH_VERSION" ]; then
399 echo -n "${funcfiletrace[1]}: "
400 else
401 echo -n "${BASH_SOURCE[1]}:${BASH_LINENO[0]}: "
402 fi
403 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 -0800404}
405
Matt Alexanderd9c56562020-05-21 10:49:17 +0000406function print_lunch_menu()
407{
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700408 local uname=$(uname)
Roland Levillain23c46cf2020-03-31 16:11:05 +0100409 local choices
Joe Onorato0e68f702024-05-24 14:19:21 -0700410 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 +0100411 local ret=$?
412
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700413 echo
414 echo "You're building on" $uname
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700415 echo
Roland Levillain23c46cf2020-03-31 16:11:05 +0100416
Matt Alexanderd9c56562020-05-21 10:49:17 +0000417 if [ $ret -ne 0 ]
418 then
Roland Levillain23c46cf2020-03-31 16:11:05 +0100419 echo "Warning: Cannot display lunch menu."
420 echo
421 echo "Note: You can invoke lunch with an explicit target:"
422 echo
423 echo " usage: lunch [target]" >&2
424 echo
425 return
426 fi
427
Will Burr40401202022-02-07 12:12:01 +0000428 echo "Lunch menu .. Here are the common combinations:"
The Android Open Source Projectdcc08f02008-12-17 18:03:49 -0800429
430 local i=1
431 local choice
Dan Willemsen91763e92019-10-03 15:13:12 -0700432 for choice in $(echo $choices)
The Android Open Source Projectdcc08f02008-12-17 18:03:49 -0800433 do
434 echo " $i. $choice"
435 i=$(($i+1))
436 done
437
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700438 echo
439}
440
Joe Onorato590ae9f2024-05-24 15:38:58 -0700441function _lunch_meat()
442{
443 local product=$1
444 local release=$2
445 local variant=$3
446
Colin Cross88737132017-03-21 17:41:03 -0700447 TARGET_PRODUCT=$product \
Jeff Hamiltona02c7472023-05-08 03:13:29 +0000448 TARGET_RELEASE=$release \
Joe Onorato590ae9f2024-05-24 15:38:58 -0700449 TARGET_BUILD_VARIANT=$variant \
Colin Cross88737132017-03-21 17:41:03 -0700450 build_build_var_cache
Matt Alexanderd9c56562020-05-21 10:49:17 +0000451 if [ $? -ne 0 ]
452 then
Anton Hansson32fa7ee2021-06-14 17:09:58 +0100453 if [[ "$product" =~ .*_(eng|user|userdebug) ]]
454 then
455 echo "Did you mean -${product/*_/}? (dash instead of underscore)"
456 fi
Colin Cross88737132017-03-21 17:41:03 -0700457 return 1
458 fi
Joe Onorato0e68f702024-05-24 14:19:21 -0700459 export TARGET_PRODUCT=$(_get_build_var_cached TARGET_PRODUCT)
460 export TARGET_BUILD_VARIANT=$(_get_build_var_cached TARGET_BUILD_VARIANT)
Greg Kaiser5e2d3392023-10-27 14:15:48 -0600461 export TARGET_RELEASE=$release
462 # Note this is the string "release", not the value of the variable.
Jeff Browne33ba4c2011-07-11 22:11:46 -0700463 export TARGET_BUILD_TYPE=release
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700464
Mark White2c807512023-10-25 17:27:07 +0000465 [[ -n "${ANDROID_QUIET_BUILD:-}" ]] || echo
466
467 set_stuff_for_environment
468 [[ -n "${ANDROID_QUIET_BUILD:-}" ]] || printconfig
469
Joe Onorato590ae9f2024-05-24 15:38:58 -0700470 if [[ -z "${ANDROID_QUIET_BUILD}" ]]; then
471 local spam_for_lunch=$(gettop)/build/make/tools/envsetup/spam_for_lunch
472 if [[ -x $spam_for_lunch ]]; then
473 $spam_for_lunch
474 fi
Will Burr40401202022-02-07 12:12:01 +0000475 fi
476
Ying Wang08800fd2016-03-03 20:57:21 -0800477 destroy_build_var_cache
Kousik Kumar41dacd12021-05-11 18:38:38 -0400478
479 if [[ -n "${CHECK_MU_CONFIG:-}" ]]; then
480 check_mu_config
481 fi
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700482}
483
Dan Willemsenaf2e1f82018-04-04 15:41:41 -0700484unset COMMON_LUNCH_CHOICES_CACHE
Jeff Davidson513d7a42010-08-02 10:00:44 -0700485# Tab completion for lunch.
Matt Alexanderd9c56562020-05-21 10:49:17 +0000486function _lunch()
487{
Jeff Davidson513d7a42010-08-02 10:00:44 -0700488 local cur prev opts
489 COMPREPLY=()
490 cur="${COMP_WORDS[COMP_CWORD]}"
491 prev="${COMP_WORDS[COMP_CWORD-1]}"
492
Dan Willemsenaf2e1f82018-04-04 15:41:41 -0700493 if [ -z "$COMMON_LUNCH_CHOICES_CACHE" ]; then
Joe Onorato0e68f702024-05-24 14:19:21 -0700494 COMMON_LUNCH_CHOICES_CACHE=$(TARGET_BUILD_APPS= _get_build_var_cached COMMON_LUNCH_CHOICES)
Dan Willemsenaf2e1f82018-04-04 15:41:41 -0700495 fi
496
497 COMPREPLY=( $(compgen -W "${COMMON_LUNCH_CHOICES_CACHE}" -- ${cur}) )
Jeff Davidson513d7a42010-08-02 10:00:44 -0700498 return 0
499}
Jeff Davidson513d7a42010-08-02 10:00:44 -0700500
Joe Onorato590ae9f2024-05-24 15:38:58 -0700501function _lunch_usage()
502{
503 (
504 echo "The lunch command selects the configuration to use for subsequent"
505 echo "Android builds."
506 echo
507 echo "Usage: lunch TARGET_PRODUCT [TARGET_RELEASE [TARGET_BUILD_VARIANT]]"
508 echo
509 echo " Choose the product, release and variant to use. If not"
510 echo " supplied, TARGET_RELEASE will be 'trunk_staging' and"
511 echo " TARGET_BUILD_VARIANT will be 'eng'"
512 echo
513 echo
514 echo "Usage: lunch TARGET_PRODUCT-TARGET_RELEASE-TARGET_BUILD_VARIANT"
515 echo
516 echo " Chose the product, release and variant to use. This"
517 echo " legacy format is maintained for compatibility."
518 echo
519 echo
520 echo "Note that the previous interactive menu and list of hard-coded"
521 echo "list of curated targets has been removed. If you would like the"
522 echo "list of products, release configs for a particular product, or"
Joe Onoratoa85234c2025-02-18 16:45:01 -0800523 echo "variants, run list_products list_releases or list_variants"
Joe Onorato590ae9f2024-05-24 15:38:58 -0700524 echo "respectively."
525 echo
526 ) 1>&2
527}
528
Joe Onoratoa85234c2025-02-18 16:45:01 -0800529function lunch()
Joe Onorato590ae9f2024-05-24 15:38:58 -0700530{
531 if [[ $# -eq 1 && $1 = "--help" ]]; then
532 _lunch_usage
533 return 0
534 fi
535 if [[ $# -eq 0 ]]; then
536 echo "No target specified. See lunch --help" 1>&2
537 return 1
538 fi
539 if [[ $# -gt 3 ]]; then
540 echo "Too many parameters given. See lunch --help" 1>&2
541 return 1
542 fi
543
544 local product release variant
545
546 # Handle the legacy format
547 local legacy=$(echo $1 | grep "-")
548 if [[ $# -eq 1 && -n $legacy ]]; then
549 IFS="-" read -r product release variant <<< "$1"
550 if [[ -z "$product" ]] || [[ -z "$release" ]] || [[ -z "$variant" ]]; then
551 echo "Invalid lunch combo: $1" 1>&2
552 echo "Valid combos must be of the form <product>-<release>-<variant> when using" 1>&2
553 echo "the legacy format. Run 'lunch --help' for usage." 1>&2
554 return 1
555 fi
556 fi
557
558 # Handle the new format.
559 if [[ -z $legacy ]]; then
560 product=$1
561 release=$2
562 if [[ -z $release ]]; then
563 release=trunk_staging
564 fi
565 variant=$3
566 if [[ -z $variant ]]; then
567 variant=eng
568 fi
569 fi
570
571 # Validate the selection and set all the environment stuff
572 _lunch_meat $product $release $variant
573}
574
575unset ANDROID_LUNCH_COMPLETION_PRODUCT_CACHE
576unset ANDROID_LUNCH_COMPLETION_CHOSEN_PRODUCT
577unset ANDROID_LUNCH_COMPLETION_RELEASE_CACHE
578# Tab completion for lunch.
579function _lunch_completion()
580{
581 # Available products
582 if [[ $COMP_CWORD -eq 1 ]] ; then
583 if [[ -z $ANDROID_LUNCH_COMPLETION_PRODUCT_CACHE ]]; then
584 ANDROID_LUNCH_COMPLETION_PRODUCT_CACHE=$(list_products)
585 fi
586 COMPREPLY=( $(compgen -W "${ANDROID_LUNCH_COMPLETION_PRODUCT_CACHE}" -- "${COMP_WORDS[COMP_CWORD]}") )
587 fi
588
589 # Available release configs
590 if [[ $COMP_CWORD -eq 2 ]] ; then
591 if [[ -z $ANDROID_LUNCH_COMPLETION_RELEASE_CACHE || $ANDROID_LUNCH_COMPLETION_CHOSEN_PRODUCT != ${COMP_WORDS[1]} ]] ; then
592 ANDROID_LUNCH_COMPLETION_RELEASE_CACHE=$(list_releases ${COMP_WORDS[1]})
593 ANDROID_LUNCH_COMPLETION_CHOSEN_PRODUCT=${COMP_WORDS[1]}
594 fi
595 COMPREPLY=( $(compgen -W "${ANDROID_LUNCH_COMPLETION_RELEASE_CACHE}" -- "${COMP_WORDS[COMP_CWORD]}") )
596 fi
597
598 # Available variants
599 if [[ $COMP_CWORD -eq 3 ]] ; then
600 COMPREPLY=(user userdebug eng)
601 fi
602
603 return 0
604}
605
606
Joe Onoratoda12daf2010-06-09 18:18:31 -0700607# Configures the build to build unbundled apps.
Doug Zongker0d8179e2014-04-16 11:34:34 -0700608# Run tapas with one or more app names (from LOCAL_PACKAGE_NAME)
Matt Alexanderd9c56562020-05-21 10:49:17 +0000609function tapas()
610{
Jeff Gaston9fb05d82017-08-21 18:27:00 -0700611 local showHelp="$(echo $* | xargs -n 1 echo | \grep -E '^(help)$' | xargs)"
Elliott Hughesf71c05a2020-03-06 16:46:59 -0800612 local arch="$(echo $* | xargs -n 1 echo | \grep -E '^(arm|x86|arm64|x86_64)$' | xargs)"
Greg Kaiser83ed1592023-10-26 18:37:40 +0000613 # TODO(b/307975293): Expand tapas to take release arguments (and update hmm() usage).
614 local release="trunk_staging"
Doug Zongker0d8179e2014-04-16 11:34:34 -0700615 local variant="$(echo $* | xargs -n 1 echo | \grep -E '^(user|userdebug|eng)$' | xargs)"
Jeff Hamilton5069bd62014-09-04 21:28:00 -0700616 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 -0800617 local keys="$(echo $* | xargs -n 1 echo | \grep -E '^(devkeys)$' | xargs)"
618 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)"
619
Joe Onoratoda12daf2010-06-09 18:18:31 -0700620
Jeff Gaston9fb05d82017-08-21 18:27:00 -0700621 if [ "$showHelp" != "" ]; then
622 $(gettop)/build/make/tapasHelp.sh
623 return
624 fi
625
Ying Wang67f02922012-08-22 10:25:20 -0700626 if [ $(echo $arch | wc -w) -gt 1 ]; then
627 echo "tapas: Error: Multiple build archs supplied: $arch"
628 return
629 fi
Greg Kaiser83ed1592023-10-26 18:37:40 +0000630 if [ $(echo $release | wc -w) -gt 1 ]; then
631 echo "tapas: Error: Multiple build releases supplied: $release"
632 return
633 fi
Joe Onoratoda12daf2010-06-09 18:18:31 -0700634 if [ $(echo $variant | wc -w) -gt 1 ]; then
635 echo "tapas: Error: Multiple build variants supplied: $variant"
636 return
637 fi
Jeff Hamilton5069bd62014-09-04 21:28:00 -0700638 if [ $(echo $density | wc -w) -gt 1 ]; then
639 echo "tapas: Error: Multiple densities supplied: $density"
640 return
641 fi
Colin Cross7f49a672022-01-27 18:15:53 -0800642 if [ $(echo $keys | wc -w) -gt 1 ]; then
643 echo "tapas: Error: Multiple keys supplied: $keys"
644 return
645 fi
Ying Wang67f02922012-08-22 10:25:20 -0700646
Ying Wang0a76df52015-06-08 11:57:26 -0700647 local product=aosp_arm
Ying Wang67f02922012-08-22 10:25:20 -0700648 case $arch in
Matt Alexanderd9c56562020-05-21 10:49:17 +0000649 x86) product=aosp_x86;;
650 arm64) product=aosp_arm64;;
651 x86_64) product=aosp_x86_64;;
Ying Wang67f02922012-08-22 10:25:20 -0700652 esac
Colin Cross7f49a672022-01-27 18:15:53 -0800653 if [ -n "$keys" ]; then
654 product=${product/aosp_/aosp_${keys}_}
655 fi;
656
Joe Onoratoda12daf2010-06-09 18:18:31 -0700657 if [ -z "$variant" ]; then
658 variant=eng
659 fi
Ying Wangc048c9b2010-06-24 15:08:33 -0700660 if [ -z "$apps" ]; then
661 apps=all
662 fi
Justin Morey29d225c2014-11-04 13:35:51 -0600663 if [ -z "$density" ]; then
664 density=alldpi
665 fi
Joe Onoratoda12daf2010-06-09 18:18:31 -0700666
Ying Wang67f02922012-08-22 10:25:20 -0700667 export TARGET_PRODUCT=$product
Greg Kaiser83ed1592023-10-26 18:37:40 +0000668 export TARGET_RELEASE=$release
Joe Onoratoda12daf2010-06-09 18:18:31 -0700669 export TARGET_BUILD_VARIANT=$variant
Jeff Hamilton5069bd62014-09-04 21:28:00 -0700670 export TARGET_BUILD_DENSITY=$density
Joe Onoratoda12daf2010-06-09 18:18:31 -0700671 export TARGET_BUILD_TYPE=release
672 export TARGET_BUILD_APPS=$apps
673
Ying Wang08800fd2016-03-03 20:57:21 -0800674 build_build_var_cache
Joe Onoratoda12daf2010-06-09 18:18:31 -0700675 set_stuff_for_environment
676 printconfig
Ying Wang08800fd2016-03-03 20:57:21 -0800677 destroy_build_var_cache
Joe Onoratoda12daf2010-06-09 18:18:31 -0700678}
679
Martin Stjernholmf692c752021-04-12 00:01:10 +0100680# Configures the build to build unbundled Android modules (APEXes).
681# Run banchan with one or more module names (from apex{} modules).
682function banchan()
683{
684 local showHelp="$(echo $* | xargs -n 1 echo | \grep -E '^(help)$' | xargs)"
Ulya Trafimovich08c381b2023-06-12 15:33:09 +0100685 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 -0600686 # TODO: Expand banchan to take release arguments (and update hmm() usage).
687 local release="trunk_staging"
Martin Stjernholmf692c752021-04-12 00:01:10 +0100688 local variant="$(echo $* | xargs -n 1 echo | \grep -E '^(user|userdebug|eng)$' | xargs)"
Ulya Trafimovich08c381b2023-06-12 15:33:09 +0100689 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 +0100690
691 if [ "$showHelp" != "" ]; then
692 $(gettop)/build/make/banchanHelp.sh
693 return
694 fi
695
Martin Stjernholm2b8d9232021-04-16 20:45:03 +0100696 if [ -z "$product" ]; then
Anton Hansson0328e322022-05-24 15:47:40 +0000697 product=arm64
Martin Stjernholm2b8d9232021-04-16 20:45:03 +0100698 elif [ $(echo $product | wc -w) -gt 1 ]; then
699 echo "banchan: Error: Multiple build archs or products supplied: $products"
Martin Stjernholmf692c752021-04-12 00:01:10 +0100700 return
701 fi
Greg Kaiserd35095e2023-10-27 16:04:30 -0600702 if [ $(echo $release | wc -w) -gt 1 ]; then
703 echo "banchan: Error: Multiple build releases supplied: $release"
704 return
705 fi
Martin Stjernholmf692c752021-04-12 00:01:10 +0100706 if [ $(echo $variant | wc -w) -gt 1 ]; then
707 echo "banchan: Error: Multiple build variants supplied: $variant"
708 return
709 fi
710 if [ -z "$apps" ]; then
711 echo "banchan: Error: No modules supplied"
712 return
713 fi
714
Martin Stjernholm2b8d9232021-04-16 20:45:03 +0100715 case $product in
716 arm) product=module_arm;;
Martin Stjernholmf692c752021-04-12 00:01:10 +0100717 x86) product=module_x86;;
718 arm64) product=module_arm64;;
Ulya Trafimovich08c381b2023-06-12 15:33:09 +0100719 riscv64) product=module_riscv64;;
Martin Stjernholmf692c752021-04-12 00:01:10 +0100720 x86_64) product=module_x86_64;;
Anton Hansson90ac61c2022-09-06 14:36:00 +0000721 arm64only) product=module_arm64only;;
722 x86_64only) product=module_x86_64only;;
Martin Stjernholmf692c752021-04-12 00:01:10 +0100723 esac
724 if [ -z "$variant" ]; then
725 variant=eng
726 fi
727
728 export TARGET_PRODUCT=$product
Greg Kaiserd35095e2023-10-27 16:04:30 -0600729 export TARGET_RELEASE=$release
Martin Stjernholmf692c752021-04-12 00:01:10 +0100730 export TARGET_BUILD_VARIANT=$variant
731 export TARGET_BUILD_DENSITY=alldpi
732 export TARGET_BUILD_TYPE=release
733
734 # This setup currently uses TARGET_BUILD_APPS just like tapas, but the use
735 # case is different and it may diverge in the future.
736 export TARGET_BUILD_APPS=$apps
737
738 build_build_var_cache
739 set_stuff_for_environment
740 printconfig
741 destroy_build_var_cache
742}
743
Matt Alexanderd9c56562020-05-21 10:49:17 +0000744function croot()
745{
Christopher Ferris55257d22017-03-23 11:08:58 -0700746 local T=$(gettop)
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700747 if [ "$T" ]; then
Marie Janssen32ec50a2016-04-21 16:53:39 -0700748 if [ "$1" ]; then
749 \cd $(gettop)/$1
750 else
751 \cd $(gettop)
752 fi
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700753 else
754 echo "Couldn't locate the top of the tree. Try setting TOP."
755 fi
756}
757
Matt Alexanderd9c56562020-05-21 10:49:17 +0000758function _croot()
759{
Anton Hanssonece9c482019-02-04 18:15:39 +0000760 local T=$(gettop)
761 if [ "$T" ]; then
762 local cur="${COMP_WORDS[COMP_CWORD]}"
763 k=0
764 for c in $(compgen -d ${T}/${cur}); do
765 COMPREPLY[k++]=${c#${T}/}/
766 done
767 fi
768}
769
Matt Alexanderd9c56562020-05-21 10:49:17 +0000770function cproj()
771{
Colin Cross6cdc5d22017-10-20 11:37:33 -0700772 local TOPFILE=build/make/core/envsetup.mk
Joe Onorato2a5d4d82009-07-30 10:23:21 -0700773 local HERE=$PWD
Christopher Ferris55257d22017-03-23 11:08:58 -0700774 local T=
Joe Onorato2a5d4d82009-07-30 10:23:21 -0700775 while [ \( ! \( -f $TOPFILE \) \) -a \( $PWD != "/" \) ]; do
776 T=$PWD
777 if [ -f "$T/Android.mk" ]; then
Ying Wang9cd17642012-12-13 10:52:07 -0800778 \cd $T
Joe Onorato2a5d4d82009-07-30 10:23:21 -0700779 return
780 fi
Ying Wang9cd17642012-12-13 10:52:07 -0800781 \cd ..
Joe Onorato2a5d4d82009-07-30 10:23:21 -0700782 done
Ying Wang9cd17642012-12-13 10:52:07 -0800783 \cd $HERE
Joe Onorato2a5d4d82009-07-30 10:23:21 -0700784 echo "can't find Android.mk"
785}
786
Elliott Hughes86e99172024-03-21 16:55:08 +0000787# Ensure that we're always using the adb in the tree. This works around the fact
788# that bash caches $PATH lookups, so if you use adb before lunching/building the
789# one in your tree, you'll continue to get /usr/bin/adb or whatever even after
790# you have the one from your current tree on your path. Historically this would
791# cause confusion because glinux had adb in /usr/bin/ by default, though that
792# doesn't appear to be the case on my rodete hosts; it is however still the case
793# that my Mac has /usr/local/bin/adb installed by default and on the default
794# path.
Shaju Mathew21439002023-07-10 00:53:22 +0000795function adb() {
Elliott Hughes57c47b72024-03-22 15:46:59 +0000796 # We need `command which` because zsh has a built-in `which` that's more
797 # like `type`.
798 local ADB=$(command which adb)
Elliott Hughes7e7ff752024-03-20 17:23:40 -0700799 if [ -z "$ADB" ]; then
800 echo "Command adb not found; try lunch (and building) first?"
801 return 1
802 fi
Zhuoyao Zhang60dd9dd2024-04-19 00:07:59 +0000803 run_tool_with_logging "ADB" $ADB "${@}"
Shaju Mathew21439002023-07-10 00:53:22 +0000804}
805
Zhuoyao Zhangf02aadf2024-06-10 18:28:25 +0000806function fastboot() {
807 local FASTBOOT=$(command which fastboot)
808 if [ -z "$FASTBOOT" ]; then
809 echo "Command fastboot not found; try lunch (and building) first?"
810 return 1
811 fi
812 # Support tool event logging for fastboot command.
813 run_tool_with_logging "FASTBOOT" $FASTBOOT "${@}"
814}
815
The Android Open Source Projectdcc08f02008-12-17 18:03:49 -0800816# communicate with a running device or emulator, set up necessary state,
817# and run the hat command.
Matt Alexanderd9c56562020-05-21 10:49:17 +0000818function runhat()
819{
The Android Open Source Projectdcc08f02008-12-17 18:03:49 -0800820 # process standard adb options
821 local adbTarget=""
Matt Alexanderd9c56562020-05-21 10:49:17 +0000822 if [ "$1" = "-d" -o "$1" = "-e" ]; then
The Android Open Source Projectdcc08f02008-12-17 18:03:49 -0800823 adbTarget=$1
824 shift 1
Matt Alexanderd9c56562020-05-21 10:49:17 +0000825 elif [ "$1" = "-s" ]; then
The Android Open Source Projectdcc08f02008-12-17 18:03:49 -0800826 adbTarget="$1 $2"
827 shift 2
828 fi
829 local adbOptions=${adbTarget}
Matt Alexanderd9c56562020-05-21 10:49:17 +0000830 #echo adbOptions = ${adbOptions}
The Android Open Source Projectdcc08f02008-12-17 18:03:49 -0800831
832 # runhat options
833 local targetPid=$1
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700834
Matt Alexanderd9c56562020-05-21 10:49:17 +0000835 if [ "$targetPid" = "" ]; then
Andy McFaddenb6289852010-07-12 08:00:19 -0700836 echo "Usage: runhat [ -d | -e | -s serial ] target-pid"
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700837 return
838 fi
839
The Android Open Source Projectdcc08f02008-12-17 18:03:49 -0800840 # confirm hat is available
841 if [ -z $(which hat) ]; then
842 echo "hat is not available in this configuration."
843 return
844 fi
845
Andy McFaddenb6289852010-07-12 08:00:19 -0700846 # issue "am" command to cause the hprof dump
Nick Kralevich9948b1e2014-07-18 15:45:38 -0700847 local devFile=/data/local/tmp/hprof-$targetPid
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700848 echo "Poking $targetPid and waiting for data..."
Dianne Hackborn6b9549f2012-09-26 15:00:59 -0700849 echo "Storing data at $devFile"
Andy McFaddenb6289852010-07-12 08:00:19 -0700850 adb ${adbOptions} shell am dumpheap $targetPid $devFile
The Android Open Source Project88b60792009-03-03 19:28:42 -0800851 echo "Press enter when logcat shows \"hprof: heap dump completed\""
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700852 echo -n "> "
853 read
854
The Android Open Source Project88b60792009-03-03 19:28:42 -0800855 local localFile=/tmp/$$-hprof
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700856
The Android Open Source Project88b60792009-03-03 19:28:42 -0800857 echo "Retrieving file $devFile..."
858 adb ${adbOptions} pull $devFile $localFile
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700859
The Android Open Source Project88b60792009-03-03 19:28:42 -0800860 adb ${adbOptions} shell rm $devFile
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700861
The Android Open Source Project88b60792009-03-03 19:28:42 -0800862 echo "Running hat on $localFile"
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700863 echo "View the output by pointing your browser at http://localhost:7000/"
864 echo ""
Dianne Hackborn6e4e1bb2011-11-10 15:19:51 -0800865 hat -JXmx512m $localFile
The Android Open Source Projectb6c1cf62008-10-21 07:00:00 -0700866}
867
The Android Open Source Project88b60792009-03-03 19:28:42 -0800868function godir () {
869 if [[ -z "$1" ]]; then
870 echo "Usage: godir <regex>"
871 return
872 fi
Christopher Ferris55257d22017-03-23 11:08:58 -0700873 local T=$(gettop)
874 local FILELIST
Matt Alexanderd9c56562020-05-21 10:49:17 +0000875 if [ ! "$OUT_DIR" = "" ]; then
Brian Carlstromf2257422015-09-30 20:28:54 -0700876 mkdir -p $OUT_DIR
877 FILELIST=$OUT_DIR/filelist
878 else
879 FILELIST=$T/filelist
880 fi
881 if [[ ! -f $FILELIST ]]; then
The Android Open Source Project88b60792009-03-03 19:28:42 -0800882 echo -n "Creating index..."
Brian Carlstromf2257422015-09-30 20:28:54 -0700883 (\cd $T; find . -wholename ./out -prune -o -wholename ./.repo -prune -o -type f > $FILELIST)
The Android Open Source Project88b60792009-03-03 19:28:42 -0800884 echo " Done"
885 echo ""
886 fi
887 local lines
Brian Carlstromf2257422015-09-30 20:28:54 -0700888 lines=($(\grep "$1" $FILELIST | sed -e 's/\/[^/]*$//' | sort | uniq))
Matt Alexanderd9c56562020-05-21 10:49:17 +0000889 if [[ ${#lines[@]} = 0 ]]; then
The Android Open Source Project88b60792009-03-03 19:28:42 -0800890 echo "Not found"
891 return
892 fi
893 local pathname
894 local choice
895 if [[ ${#lines[@]} > 1 ]]; then
896 while [[ -z "$pathname" ]]; do
897 local index=1
898 local line
899 for line in ${lines[@]}; do
900 printf "%6s %s\n" "[$index]" $line
Doug Zongker29034982011-04-22 08:16:56 -0700901 index=$(($index + 1))
The Android Open Source Project88b60792009-03-03 19:28:42 -0800902 done
903 echo
904 echo -n "Select one: "
905 unset choice
906 read choice
907 if [[ $choice -gt ${#lines[@]} || $choice -lt 1 ]]; then
908 echo "Invalid choice"
909 continue
910 fi
Guillaume Chelfice000fd2019-10-03 12:02:46 +0200911 pathname=${lines[@]:$(($choice-1)):1}
The Android Open Source Project88b60792009-03-03 19:28:42 -0800912 done
913 else
Guillaume Chelfice000fd2019-10-03 12:02:46 +0200914 pathname=${lines[@]:0:1}
The Android Open Source Project88b60792009-03-03 19:28:42 -0800915 fi
Ying Wang9cd17642012-12-13 10:52:07 -0800916 \cd $T/$pathname
The Android Open Source Project88b60792009-03-03 19:28:42 -0800917}
918
Rett Berg78d1c932019-01-24 14:34:23 -0800919# Go to a specific module in the android tree, as cached in module-info.json. If any build change
920# is made, and it should be reflected in the output, you should run 'refreshmod' first.
Joe Onorato6b543832024-05-23 12:26:50 -0700921# Note: This function is in envsetup because changing the directory needs to happen in the current
922# shell. All other functions that use module-info.json should be in build/soong/bin.
Rett Berg78d1c932019-01-24 14:34:23 -0800923function gomod() {
924 if [[ $# -ne 1 ]]; then
925 echo "usage: gomod <module>" >&2
926 return 1
927 fi
928
929 local path="$(pathmod $@)"
930 if [ -z "$path" ]; then
931 return 1
932 fi
933 cd $path
934}
935
dimitry73b84812018-12-11 18:06:00 +0100936function _complete_android_module_names() {
Steven Moreland62054a42018-12-06 10:11:40 -0800937 local word=${COMP_WORDS[COMP_CWORD]}
Cole Faust5d825b72022-10-26 18:16:44 -0700938 COMPREPLY=( $(allmod | grep -E "^$word") )
Steven Moreland62054a42018-12-06 10:11:40 -0800939}
940
Matt Alexanderd9c56562020-05-21 10:49:17 +0000941function get_make_command()
942{
Dan Willemsend41ec5a2017-07-12 16:14:50 -0700943 # If we're in the top of an Android tree, use soong_ui.bash instead of make
944 if [ -f build/soong/soong_ui.bash ]; then
Dan Willemsene9842242017-07-28 13:00:13 -0700945 # Always use the real make if -C is passed in
946 for arg in "$@"; do
947 if [[ $arg == -C* ]]; then
948 echo command make
949 return
950 fi
951 done
Dan Willemsend41ec5a2017-07-12 16:14:50 -0700952 echo build/soong/soong_ui.bash --make-mode
953 else
954 echo command make
955 fi
Ying Wanged21d4c2014-08-24 22:14:19 -0700956}
957
Matt Alexanderd9c56562020-05-21 10:49:17 +0000958function make()
959{
Dan Willemsene9842242017-07-28 13:00:13 -0700960 _wrap_build $(get_make_command "$@") "$@"
Dan Willemsend41ec5a2017-07-12 16:14:50 -0700961}
962
Jim Tanga881a252018-06-19 16:34:41 +0800963# Zsh needs bashcompinit called to support bash-style completion.
Patrik Fimmldf248e62018-10-15 18:15:12 +0200964function enable_zsh_completion() {
965 # Don't override user's options if bash-style completion is already enabled.
966 if ! declare -f complete >/dev/null; then
967 autoload -U compinit && compinit
968 autoload -U bashcompinit && bashcompinit
969 fi
Jim Tanga881a252018-06-19 16:34:41 +0800970}
971
972function validate_current_shell() {
973 local current_sh="$(ps -o command -p $$)"
974 case "$current_sh" in
Raphael Moll70a86b02011-06-20 16:03:14 -0700975 *bash*)
Jim Tanga881a252018-06-19 16:34:41 +0800976 function check_type() { type -t "$1"; }
Raphael Moll70a86b02011-06-20 16:03:14 -0700977 ;;
Jim Tanga881a252018-06-19 16:34:41 +0800978 *zsh*)
979 function check_type() { type "$1"; }
Matt Alexanderd9c56562020-05-21 10:49:17 +0000980 enable_zsh_completion ;;
Raphael Moll70a86b02011-06-20 16:03:14 -0700981 *)
Jim Tanga881a252018-06-19 16:34:41 +0800982 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 -0700983 ;;
984 esac
Jim Tanga881a252018-06-19 16:34:41 +0800985}
The Android Open Source Projectdcc08f02008-12-17 18:03:49 -0800986
987# Execute the contents of any vendorsetup.sh files we can find.
Dan Willemsend855a722019-02-12 15:52:36 -0800988# Unless we find an allowed-vendorsetup_sh-files file, in which case we'll only
989# load those.
990#
991# This allows loading only approved vendorsetup.sh files
Jim Tanga881a252018-06-19 16:34:41 +0800992function source_vendorsetup() {
Jim Tangc4dba1d2019-07-25 16:54:27 +0800993 unset VENDOR_PYTHONPATH
Patrice Arrudaaa4b8242020-10-12 21:29:14 +0000994 local T="$(gettop)"
Dan Willemsend855a722019-02-12 15:52:36 -0800995 allowed=
Patrice Arrudaaa4b8242020-10-12 21:29:14 +0000996 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 -0800997 if [ -n "$allowed" ]; then
998 echo "More than one 'allowed_vendorsetup_sh-files' file found, not including any vendorsetup.sh files:"
999 echo " $allowed"
1000 echo " $f"
1001 return
1002 fi
Patrice Arrudaaa4b8242020-10-12 21:29:14 +00001003 allowed="$T/$f"
Dan Willemsend855a722019-02-12 15:52:36 -08001004 done
1005
1006 allowed_files=
1007 [ -n "$allowed" ] && allowed_files=$(cat "$allowed")
Jim Tanga881a252018-06-19 16:34:41 +08001008 for dir in device vendor product; do
Patrice Arrudaaa4b8242020-10-12 21:29:14 +00001009 for f in $(cd "$T" && test -d $dir && \
Jim Tanga881a252018-06-19 16:34:41 +08001010 find -L $dir -maxdepth 4 -name 'vendorsetup.sh' 2>/dev/null | sort); do
Dan Willemsend855a722019-02-12 15:52:36 -08001011
1012 if [[ -z "$allowed" || "$allowed_files" =~ $f ]]; then
Patrice Arrudaaa4b8242020-10-12 21:29:14 +00001013 echo "including $f"; . "$T/$f"
Dan Willemsend855a722019-02-12 15:52:36 -08001014 else
1015 echo "ignoring $f, not in $allowed"
1016 fi
Jim Tanga881a252018-06-19 16:34:41 +08001017 done
1018 done
Kousik Kumarec5416c2023-09-14 17:11:45 +00001019
Sam Lewis2404c4a2024-09-23 20:06:02 +00001020 setup_cog_env_if_needed
Jim Tanga881a252018-06-19 16:34:41 +08001021}
Kenny Root52aa81c2011-07-15 11:07:06 -07001022
Dan Albertbab814f2020-08-26 15:34:53 -07001023function showcommands() {
1024 local T=$(gettop)
1025 if [[ -z "$TARGET_PRODUCT" ]]; then
1026 >&2 echo "TARGET_PRODUCT not set. Run lunch."
1027 return
1028 fi
1029 case $(uname -s) in
1030 Darwin)
1031 PREBUILT_NAME=darwin-x86
1032 ;;
1033 Linux)
1034 PREBUILT_NAME=linux-x86
1035 ;;
1036 *)
1037 >&2 echo Unknown host $(uname -s)
1038 return
1039 ;;
1040 esac
Joe Onorato0e68f702024-05-24 14:19:21 -07001041 OUT_DIR="$(_get_abs_build_var_cached OUT_DIR)"
Dan Albertbab814f2020-08-26 15:34:53 -07001042 if [[ "$1" == "--regenerate" ]]; then
1043 shift 1
1044 NINJA_ARGS="-t commands $@" m
1045 else
1046 (cd $T && prebuilts/build-tools/$PREBUILT_NAME/bin/ninja \
1047 -f $OUT_DIR/combined-${TARGET_PRODUCT}.ninja \
1048 -t commands "$@")
1049 fi
1050}
1051
Joe Onorato1b9ab292024-05-17 12:16:43 -07001052# These functions used to be here but are now standalone scripts
1053# in build/soong/bin. Unset these for the time being so the real
1054# script is picked up.
Joe Onorato23124752024-05-14 15:06:48 -07001055# TODO: Remove this some time after a suitable delay (maybe 2025?)
Joe Onorato6b543832024-05-23 12:26:50 -07001056unset allmod
Joe Onorato23124752024-05-14 15:06:48 -07001057unset aninja
Joe Onorato1b9ab292024-05-17 12:16:43 -07001058unset cgrep
Joe Onorato3acb3082024-05-24 14:14:46 -07001059unset core
1060unset coredump_enable
1061unset coredump_setup
Joe Onorato6b543832024-05-23 12:26:50 -07001062unset dirmods
Joe Onorato0e68f702024-05-24 14:19:21 -07001063unset get_build_var
1064unset get_abs_build_var
Joe Onorato3acb3082024-05-24 14:14:46 -07001065unset getlastscreenshot
1066unset getprebuilt
1067unset getscreenshotpath
1068unset getsdcardpath
1069unset gettargetarch
Joe Onorato1b9ab292024-05-17 12:16:43 -07001070unset ggrep
1071unset gogrep
Joe Onorato3acb3082024-05-24 14:14:46 -07001072unset hmm
Joe Onorato6b543832024-05-23 12:26:50 -07001073unset installmod
Joe Onorato3acb3082024-05-24 14:14:46 -07001074unset is64bit
1075unset isviewserverstarted
Joe Onorato1b9ab292024-05-17 12:16:43 -07001076unset jgrep
1077unset jsongrep
Joe Onorato3acb3082024-05-24 14:14:46 -07001078unset key_back
1079unset key_home
1080unset key_menu
Joe Onorato1b9ab292024-05-17 12:16:43 -07001081unset ktgrep
Joe Onorato6b543832024-05-23 12:26:50 -07001082unset m
Joe Onorato1b9ab292024-05-17 12:16:43 -07001083unset mangrep
1084unset mgrep
Joe Onorato6b543832024-05-23 12:26:50 -07001085unset mm
1086unset mma
1087unset mmm
1088unset mmma
1089unset outmod
1090unset overrideflags
Joe Onorato1b9ab292024-05-17 12:16:43 -07001091unset owngrep
Joe Onorato6b543832024-05-23 12:26:50 -07001092unset pathmod
Joe Onoratoff277c52024-05-23 12:52:07 -07001093unset pez
Joe Onorato1b9ab292024-05-17 12:16:43 -07001094unset pygrep
Joe Onorato6b543832024-05-23 12:26:50 -07001095unset qpid
Joe Onorato1b9ab292024-05-17 12:16:43 -07001096unset rcgrep
Joe Onorato6b543832024-05-23 12:26:50 -07001097unset refreshmod
Joe Onorato1b9ab292024-05-17 12:16:43 -07001098unset resgrep
1099unset rsgrep
Zhuoyao Zhang1698d492024-05-21 23:55:27 +00001100unset run_tool_with_logging
Joe Onorato1b9ab292024-05-17 12:16:43 -07001101unset sepgrep
1102unset sgrep
Joe Onorato3acb3082024-05-24 14:14:46 -07001103unset startviewserver
1104unset stopviewserver
1105unset systemstack
Joe Onorato6b543832024-05-23 12:26:50 -07001106unset syswrite
Joe Onorato1b9ab292024-05-17 12:16:43 -07001107unset tomlgrep
1108unset treegrep
Cole Faust45844ab2022-08-30 13:59:07 -07001109
Colin Cross71319722023-10-24 10:58:46 -07001110
Jim Tanga881a252018-06-19 16:34:41 +08001111validate_current_shell
Joe Onorato7c3a77f2022-12-05 13:05:14 -08001112set_global_paths
Jim Tanga881a252018-06-19 16:34:41 +08001113source_vendorsetup
Kenny Root52aa81c2011-07-15 11:07:06 -07001114addcompletions
Joe Onorato7c3a77f2022-12-05 13:05:14 -08001115
Joe Onorato23124752024-05-14 15:06:48 -07001116