envsetup.sh revision 0c1374cc709389d6a21cf426ec93d1669e04e143
1function hmm() { 2cat <<EOF 3Invoke ". build/envsetup.sh" from your shell to add the following functions to your environment: 4- lunch: lunch <product_name>-<build_variant> 5- tapas: tapas [<App1> <App2> ...] [arm|x86|mips|armv5|arm64|x86_64|mips64] [eng|userdebug|user] 6- croot: Changes directory to the top of the tree. 7- m: Makes from the top of the tree. 8- mm: Builds all of the modules in the current directory, but not their dependencies. 9- mmm: Builds all of the modules in the supplied directories, but not their dependencies. 10 To limit the modules being built use the syntax: mmm dir/:target1,target2. 11- mma: Builds all of the modules in the current directory, and their dependencies. 12- mmma: Builds all of the modules in the supplied directories, and their dependencies. 13- cgrep: Greps on all local C/C++ files. 14- ggrep: Greps on all local Gradle files. 15- jgrep: Greps on all local Java files. 16- resgrep: Greps on all local res/*.xml files. 17- mangrep: Greps on all local AndroidManifest.xml files. 18- sepgrep: Greps on all local sepolicy files. 19- sgrep: Greps on all local source files. 20- godir: Go to the directory containing a file. 21 22Environemnt options: 23- SANITIZE_HOST: Set to 'true' to use ASAN for all host modules. Note that 24 ASAN_OPTIONS=detect_leaks=0 will be set by default until the 25 build is leak-check clean. 26 27Look at the source to view more functions. The complete list is: 28EOF 29 T=$(gettop) 30 local A 31 A="" 32 for i in `cat $T/build/envsetup.sh | sed -n "/^[ \t]*function /s/function \([a-z_]*\).*/\1/p" | sort | uniq`; do 33 A="$A $i" 34 done 35 echo $A 36} 37 38# Get the value of a build variable as an absolute path. 39function get_abs_build_var() 40{ 41 T=$(gettop) 42 if [ ! "$T" ]; then 43 echo "Couldn't locate the top of the tree. Try setting TOP." >&2 44 return 45 fi 46 (\cd $T; CALLED_FROM_SETUP=true BUILD_SYSTEM=build/core \ 47 command make --no-print-directory -f build/core/config.mk dumpvar-abs-$1) 48} 49 50# Get the exact value of a build variable. 51function get_build_var() 52{ 53 T=$(gettop) 54 if [ ! "$T" ]; then 55 echo "Couldn't locate the top of the tree. Try setting TOP." >&2 56 return 57 fi 58 (\cd $T; CALLED_FROM_SETUP=true BUILD_SYSTEM=build/core \ 59 command make --no-print-directory -f build/core/config.mk dumpvar-$1) 60} 61 62# check to see if the supplied product is one we can build 63function check_product() 64{ 65 T=$(gettop) 66 if [ ! "$T" ]; then 67 echo "Couldn't locate the top of the tree. Try setting TOP." >&2 68 return 69 fi 70 TARGET_PRODUCT=$1 \ 71 TARGET_BUILD_VARIANT= \ 72 TARGET_BUILD_TYPE= \ 73 TARGET_BUILD_APPS= \ 74 get_build_var TARGET_DEVICE > /dev/null 75 # hide successful answers, but allow the errors to show 76} 77 78VARIANT_CHOICES=(user userdebug eng) 79 80# check to see if the supplied variant is valid 81function check_variant() 82{ 83 for v in ${VARIANT_CHOICES[@]} 84 do 85 if [ "$v" = "$1" ] 86 then 87 return 0 88 fi 89 done 90 return 1 91} 92 93function setpaths() 94{ 95 T=$(gettop) 96 if [ ! "$T" ]; then 97 echo "Couldn't locate the top of the tree. Try setting TOP." 98 return 99 fi 100 101 ################################################################## 102 # # 103 # Read me before you modify this code # 104 # # 105 # This function sets ANDROID_BUILD_PATHS to what it is adding # 106 # to PATH, and the next time it is run, it removes that from # 107 # PATH. This is required so lunch can be run more than once # 108 # and still have working paths. # 109 # # 110 ################################################################## 111 112 # Note: on windows/cygwin, ANDROID_BUILD_PATHS will contain spaces 113 # due to "C:\Program Files" being in the path. 114 115 # out with the old 116 if [ -n "$ANDROID_BUILD_PATHS" ] ; then 117 export PATH=${PATH/$ANDROID_BUILD_PATHS/} 118 fi 119 if [ -n "$ANDROID_PRE_BUILD_PATHS" ] ; then 120 export PATH=${PATH/$ANDROID_PRE_BUILD_PATHS/} 121 # strip leading ':', if any 122 export PATH=${PATH/:%/} 123 fi 124 125 # and in with the new 126 prebuiltdir=$(getprebuilt) 127 gccprebuiltdir=$(get_abs_build_var ANDROID_GCC_PREBUILTS) 128 129 # defined in core/config.mk 130 targetgccversion=$(get_build_var TARGET_GCC_VERSION) 131 targetgccversion2=$(get_build_var 2ND_TARGET_GCC_VERSION) 132 export TARGET_GCC_VERSION=$targetgccversion 133 134 # The gcc toolchain does not exists for windows/cygwin. In this case, do not reference it. 135 export ANDROID_TOOLCHAIN= 136 export ANDROID_TOOLCHAIN_2ND_ARCH= 137 local ARCH=$(get_build_var TARGET_ARCH) 138 case $ARCH in 139 x86) toolchaindir=x86/x86_64-linux-android-$targetgccversion/bin 140 ;; 141 x86_64) toolchaindir=x86/x86_64-linux-android-$targetgccversion/bin 142 ;; 143 arm) toolchaindir=arm/arm-linux-androideabi-$targetgccversion/bin 144 ;; 145 arm64) toolchaindir=aarch64/aarch64-linux-android-$targetgccversion/bin; 146 toolchaindir2=arm/arm-linux-androideabi-$targetgccversion2/bin 147 ;; 148 mips|mips64) toolchaindir=mips/mips64el-linux-android-$targetgccversion/bin 149 ;; 150 *) 151 echo "Can't find toolchain for unknown architecture: $ARCH" 152 toolchaindir=xxxxxxxxx 153 ;; 154 esac 155 if [ -d "$gccprebuiltdir/$toolchaindir" ]; then 156 export ANDROID_TOOLCHAIN=$gccprebuiltdir/$toolchaindir 157 fi 158 159 if [ -d "$gccprebuiltdir/$toolchaindir2" ]; then 160 export ANDROID_TOOLCHAIN_2ND_ARCH=$gccprebuiltdir/$toolchaindir2 161 fi 162 163 unset ANDROID_KERNEL_TOOLCHAIN_PATH 164 case $ARCH in 165 arm) 166 # Legacy toolchain configuration used for ARM kernel compilation 167 toolchaindir=arm/arm-eabi-$targetgccversion/bin 168 if [ -d "$gccprebuiltdir/$toolchaindir" ]; then 169 export ARM_EABI_TOOLCHAIN="$gccprebuiltdir/$toolchaindir" 170 ANDROID_KERNEL_TOOLCHAIN_PATH="$ARM_EABI_TOOLCHAIN": 171 fi 172 ;; 173 *) 174 # No need to set ARM_EABI_TOOLCHAIN for other ARCHs 175 ;; 176 esac 177 178 export ANDROID_DEV_SCRIPTS=$T/development/scripts:$T/prebuilts/devtools/tools 179 export ANDROID_BUILD_PATHS=$(get_build_var ANDROID_BUILD_PATHS):$ANDROID_TOOLCHAIN:$ANDROID_TOOLCHAIN_2ND_ARCH:$ANDROID_KERNEL_TOOLCHAIN_PATH$ANDROID_DEV_SCRIPTS: 180 181 # If prebuilts/android-emulator/<system>/ exists, prepend it to our PATH 182 # to ensure that the corresponding 'emulator' binaries are used. 183 case $(uname -s) in 184 Darwin) 185 ANDROID_EMULATOR_PREBUILTS=$T/prebuilts/android-emulator/darwin-x86_64 186 ;; 187 Linux) 188 ANDROID_EMULATOR_PREBUILTS=$T/prebuilts/android-emulator/linux-x86_64 189 ;; 190 *) 191 ANDROID_EMULATOR_PREBUILTS= 192 ;; 193 esac 194 if [ -n "$ANDROID_EMULATOR_PREBUILTS" -a -d "$ANDROID_EMULATOR_PREBUILTS" ]; then 195 ANDROID_BUILD_PATHS=$ANDROID_BUILD_PATHS$ANDROID_EMULATOR_PREBUILTS: 196 export ANDROID_EMULATOR_PREBUILTS 197 fi 198 199 export PATH=$ANDROID_BUILD_PATHS$PATH 200 201 unset ANDROID_JAVA_TOOLCHAIN 202 unset ANDROID_PRE_BUILD_PATHS 203 if [ -n "$JAVA_HOME" ]; then 204 export ANDROID_JAVA_TOOLCHAIN=$JAVA_HOME/bin 205 export ANDROID_PRE_BUILD_PATHS=$ANDROID_JAVA_TOOLCHAIN: 206 export PATH=$ANDROID_PRE_BUILD_PATHS$PATH 207 fi 208 209 unset ANDROID_PRODUCT_OUT 210 export ANDROID_PRODUCT_OUT=$(get_abs_build_var PRODUCT_OUT) 211 export OUT=$ANDROID_PRODUCT_OUT 212 213 unset ANDROID_HOST_OUT 214 export ANDROID_HOST_OUT=$(get_abs_build_var HOST_OUT) 215 216 # needed for building linux on MacOS 217 # TODO: fix the path 218 #export HOST_EXTRACFLAGS="-I "$T/system/kernel_headers/host_include 219} 220 221function printconfig() 222{ 223 T=$(gettop) 224 if [ ! "$T" ]; then 225 echo "Couldn't locate the top of the tree. Try setting TOP." >&2 226 return 227 fi 228 get_build_var report_config 229} 230 231function set_stuff_for_environment() 232{ 233 settitle 234 set_java_home 235 setpaths 236 set_sequence_number 237 238 export ANDROID_BUILD_TOP=$(gettop) 239 # With this environment variable new GCC can apply colors to warnings/errors 240 export GCC_COLORS='error=01;31:warning=01;35:note=01;36:caret=01;32:locus=01:quote=01' 241 export ASAN_OPTIONS=detect_leaks=0 242} 243 244function set_sequence_number() 245{ 246 export BUILD_ENV_SEQUENCE_NUMBER=10 247} 248 249function settitle() 250{ 251 if [ "$STAY_OFF_MY_LAWN" = "" ]; then 252 local arch=$(gettargetarch) 253 local product=$TARGET_PRODUCT 254 local variant=$TARGET_BUILD_VARIANT 255 local apps=$TARGET_BUILD_APPS 256 if [ -z "$apps" ]; then 257 export PROMPT_COMMAND="echo -ne \"\033]0;[${arch}-${product}-${variant}] ${USER}@${HOSTNAME}: ${PWD}\007\"" 258 else 259 export PROMPT_COMMAND="echo -ne \"\033]0;[$arch $apps $variant] ${USER}@${HOSTNAME}: ${PWD}\007\"" 260 fi 261 fi 262} 263 264function addcompletions() 265{ 266 local T dir f 267 268 # Keep us from trying to run in something that isn't bash. 269 if [ -z "${BASH_VERSION}" ]; then 270 return 271 fi 272 273 # Keep us from trying to run in bash that's too old. 274 if [ ${BASH_VERSINFO[0]} -lt 3 ]; then 275 return 276 fi 277 278 dir="sdk/bash_completion" 279 if [ -d ${dir} ]; then 280 for f in `/bin/ls ${dir}/[a-z]*.bash 2> /dev/null`; do 281 echo "including $f" 282 . $f 283 done 284 fi 285} 286 287function choosetype() 288{ 289 echo "Build type choices are:" 290 echo " 1. release" 291 echo " 2. debug" 292 echo 293 294 local DEFAULT_NUM DEFAULT_VALUE 295 DEFAULT_NUM=1 296 DEFAULT_VALUE=release 297 298 export TARGET_BUILD_TYPE= 299 local ANSWER 300 while [ -z $TARGET_BUILD_TYPE ] 301 do 302 echo -n "Which would you like? ["$DEFAULT_NUM"] " 303 if [ -z "$1" ] ; then 304 read ANSWER 305 else 306 echo $1 307 ANSWER=$1 308 fi 309 case $ANSWER in 310 "") 311 export TARGET_BUILD_TYPE=$DEFAULT_VALUE 312 ;; 313 1) 314 export TARGET_BUILD_TYPE=release 315 ;; 316 release) 317 export TARGET_BUILD_TYPE=release 318 ;; 319 2) 320 export TARGET_BUILD_TYPE=debug 321 ;; 322 debug) 323 export TARGET_BUILD_TYPE=debug 324 ;; 325 *) 326 echo 327 echo "I didn't understand your response. Please try again." 328 echo 329 ;; 330 esac 331 if [ -n "$1" ] ; then 332 break 333 fi 334 done 335 336 set_stuff_for_environment 337} 338 339# 340# This function isn't really right: It chooses a TARGET_PRODUCT 341# based on the list of boards. Usually, that gets you something 342# that kinda works with a generic product, but really, you should 343# pick a product by name. 344# 345function chooseproduct() 346{ 347 if [ "x$TARGET_PRODUCT" != x ] ; then 348 default_value=$TARGET_PRODUCT 349 else 350 default_value=full 351 fi 352 353 export TARGET_PRODUCT= 354 local ANSWER 355 while [ -z "$TARGET_PRODUCT" ] 356 do 357 echo -n "Which product would you like? [$default_value] " 358 if [ -z "$1" ] ; then 359 read ANSWER 360 else 361 echo $1 362 ANSWER=$1 363 fi 364 365 if [ -z "$ANSWER" ] ; then 366 export TARGET_PRODUCT=$default_value 367 else 368 if check_product $ANSWER 369 then 370 export TARGET_PRODUCT=$ANSWER 371 else 372 echo "** Not a valid product: $ANSWER" 373 fi 374 fi 375 if [ -n "$1" ] ; then 376 break 377 fi 378 done 379 380 set_stuff_for_environment 381} 382 383function choosevariant() 384{ 385 echo "Variant choices are:" 386 local index=1 387 local v 388 for v in ${VARIANT_CHOICES[@]} 389 do 390 # The product name is the name of the directory containing 391 # the makefile we found, above. 392 echo " $index. $v" 393 index=$(($index+1)) 394 done 395 396 local default_value=eng 397 local ANSWER 398 399 export TARGET_BUILD_VARIANT= 400 while [ -z "$TARGET_BUILD_VARIANT" ] 401 do 402 echo -n "Which would you like? [$default_value] " 403 if [ -z "$1" ] ; then 404 read ANSWER 405 else 406 echo $1 407 ANSWER=$1 408 fi 409 410 if [ -z "$ANSWER" ] ; then 411 export TARGET_BUILD_VARIANT=$default_value 412 elif (echo -n $ANSWER | grep -q -e "^[0-9][0-9]*$") ; then 413 if [ "$ANSWER" -le "${#VARIANT_CHOICES[@]}" ] ; then 414 export TARGET_BUILD_VARIANT=${VARIANT_CHOICES[$(($ANSWER-1))]} 415 fi 416 else 417 if check_variant $ANSWER 418 then 419 export TARGET_BUILD_VARIANT=$ANSWER 420 else 421 echo "** Not a valid variant: $ANSWER" 422 fi 423 fi 424 if [ -n "$1" ] ; then 425 break 426 fi 427 done 428} 429 430function choosecombo() 431{ 432 choosetype $1 433 434 echo 435 echo 436 chooseproduct $2 437 438 echo 439 echo 440 choosevariant $3 441 442 echo 443 set_stuff_for_environment 444 printconfig 445} 446 447# Clear this variable. It will be built up again when the vendorsetup.sh 448# files are included at the end of this file. 449unset LUNCH_MENU_CHOICES 450function add_lunch_combo() 451{ 452 local new_combo=$1 453 local c 454 for c in ${LUNCH_MENU_CHOICES[@]} ; do 455 if [ "$new_combo" = "$c" ] ; then 456 return 457 fi 458 done 459 LUNCH_MENU_CHOICES=(${LUNCH_MENU_CHOICES[@]} $new_combo) 460} 461 462# add the default one here 463add_lunch_combo aosp_arm-eng 464add_lunch_combo aosp_arm64-eng 465add_lunch_combo aosp_mips-eng 466add_lunch_combo aosp_mips64-eng 467add_lunch_combo aosp_x86-eng 468add_lunch_combo aosp_x86_64-eng 469 470function print_lunch_menu() 471{ 472 local uname=$(uname) 473 echo 474 echo "You're building on" $uname 475 echo 476 echo "Lunch menu... pick a combo:" 477 478 local i=1 479 local choice 480 for choice in ${LUNCH_MENU_CHOICES[@]} 481 do 482 echo " $i. $choice" 483 i=$(($i+1)) 484 done 485 486 echo 487} 488 489function lunch() 490{ 491 local answer 492 493 if [ "$1" ] ; then 494 answer=$1 495 else 496 print_lunch_menu 497 echo -n "Which would you like? [aosp_arm-eng] " 498 read answer 499 fi 500 501 local selection= 502 503 if [ -z "$answer" ] 504 then 505 selection=aosp_arm-eng 506 elif (echo -n $answer | grep -q -e "^[0-9][0-9]*$") 507 then 508 if [ $answer -le ${#LUNCH_MENU_CHOICES[@]} ] 509 then 510 selection=${LUNCH_MENU_CHOICES[$(($answer-1))]} 511 fi 512 elif (echo -n $answer | grep -q -e "^[^\-][^\-]*-[^\-][^\-]*$") 513 then 514 selection=$answer 515 fi 516 517 if [ -z "$selection" ] 518 then 519 echo 520 echo "Invalid lunch combo: $answer" 521 return 1 522 fi 523 524 export TARGET_BUILD_APPS= 525 526 local product=$(echo -n $selection | sed -e "s/-.*$//") 527 check_product $product 528 if [ $? -ne 0 ] 529 then 530 echo 531 echo "** Don't have a product spec for: '$product'" 532 echo "** Do you have the right repo manifest?" 533 product= 534 fi 535 536 local variant=$(echo -n $selection | sed -e "s/^[^\-]*-//") 537 check_variant $variant 538 if [ $? -ne 0 ] 539 then 540 echo 541 echo "** Invalid variant: '$variant'" 542 echo "** Must be one of ${VARIANT_CHOICES[@]}" 543 variant= 544 fi 545 546 if [ -z "$product" -o -z "$variant" ] 547 then 548 echo 549 return 1 550 fi 551 552 export TARGET_PRODUCT=$product 553 export TARGET_BUILD_VARIANT=$variant 554 export TARGET_BUILD_TYPE=release 555 556 echo 557 558 set_stuff_for_environment 559 printconfig 560} 561 562# Tab completion for lunch. 563function _lunch() 564{ 565 local cur prev opts 566 COMPREPLY=() 567 cur="${COMP_WORDS[COMP_CWORD]}" 568 prev="${COMP_WORDS[COMP_CWORD-1]}" 569 570 COMPREPLY=( $(compgen -W "${LUNCH_MENU_CHOICES[*]}" -- ${cur}) ) 571 return 0 572} 573complete -F _lunch lunch 574 575# Configures the build to build unbundled apps. 576# Run tapas with one or more app names (from LOCAL_PACKAGE_NAME) 577function tapas() 578{ 579 local arch="$(echo $* | xargs -n 1 echo | \grep -E '^(arm|x86|mips|armv5|arm64|x86_64|mips64)$' | xargs)" 580 local variant="$(echo $* | xargs -n 1 echo | \grep -E '^(user|userdebug|eng)$' | xargs)" 581 local density="$(echo $* | xargs -n 1 echo | \grep -E '^(ldpi|mdpi|tvdpi|hdpi|xhdpi|xxhdpi|xxxhdpi|alldpi)$' | xargs)" 582 local apps="$(echo $* | xargs -n 1 echo | \grep -E -v '^(user|userdebug|eng|arm|x86|mips|armv5|arm64|x86_64|mips64|ldpi|mdpi|tvdpi|hdpi|xhdpi|xxhdpi|xxxhdpi|alldpi)$' | xargs)" 583 584 if [ $(echo $arch | wc -w) -gt 1 ]; then 585 echo "tapas: Error: Multiple build archs supplied: $arch" 586 return 587 fi 588 if [ $(echo $variant | wc -w) -gt 1 ]; then 589 echo "tapas: Error: Multiple build variants supplied: $variant" 590 return 591 fi 592 if [ $(echo $density | wc -w) -gt 1 ]; then 593 echo "tapas: Error: Multiple densities supplied: $density" 594 return 595 fi 596 597 local product=full 598 case $arch in 599 x86) product=full_x86;; 600 mips) product=full_mips;; 601 armv5) product=generic_armv5;; 602 arm64) product=aosp_arm64;; 603 x86_64) product=aosp_x86_64;; 604 mips64) product=aosp_mips64;; 605 esac 606 if [ -z "$variant" ]; then 607 variant=eng 608 fi 609 if [ -z "$apps" ]; then 610 apps=all 611 fi 612 if [ -z "$density" ]; then 613 density=alldpi 614 fi 615 616 export TARGET_PRODUCT=$product 617 export TARGET_BUILD_VARIANT=$variant 618 export TARGET_BUILD_DENSITY=$density 619 export TARGET_BUILD_TYPE=release 620 export TARGET_BUILD_APPS=$apps 621 622 set_stuff_for_environment 623 printconfig 624} 625 626function gettop 627{ 628 local TOPFILE=build/core/envsetup.mk 629 if [ -n "$TOP" -a -f "$TOP/$TOPFILE" ] ; then 630 # The following circumlocution ensures we remove symlinks from TOP. 631 (cd $TOP; PWD= /bin/pwd) 632 else 633 if [ -f $TOPFILE ] ; then 634 # The following circumlocution (repeated below as well) ensures 635 # that we record the true directory name and not one that is 636 # faked up with symlink names. 637 PWD= /bin/pwd 638 else 639 local HERE=$PWD 640 T= 641 while [ \( ! \( -f $TOPFILE \) \) -a \( $PWD != "/" \) ]; do 642 \cd .. 643 T=`PWD= /bin/pwd -P` 644 done 645 \cd $HERE 646 if [ -f "$T/$TOPFILE" ]; then 647 echo $T 648 fi 649 fi 650 fi 651} 652 653# Return driver for "make", if any (eg. static analyzer) 654function getdriver() 655{ 656 local T="$1" 657 test "$WITH_STATIC_ANALYZER" = "0" && unset WITH_STATIC_ANALYZER 658 if [ -n "$WITH_STATIC_ANALYZER" ]; then 659 echo "\ 660$T/prebuilts/misc/linux-x86/analyzer/tools/scan-build/scan-build \ 661--use-analyzer $T/prebuilts/misc/linux-x86/analyzer/bin/analyzer \ 662--status-bugs \ 663--top=$T" 664 fi 665} 666 667function m() 668{ 669 local T=$(gettop) 670 local DRV=$(getdriver $T) 671 if [ "$T" ]; then 672 $DRV make -C $T -f build/core/main.mk $@ 673 else 674 echo "Couldn't locate the top of the tree. Try setting TOP." 675 return 1 676 fi 677} 678 679function findmakefile() 680{ 681 TOPFILE=build/core/envsetup.mk 682 local HERE=$PWD 683 T= 684 while [ \( ! \( -f $TOPFILE \) \) -a \( $PWD != "/" \) ]; do 685 T=`PWD= /bin/pwd` 686 if [ -f "$T/Android.mk" ]; then 687 echo $T/Android.mk 688 \cd $HERE 689 return 690 fi 691 \cd .. 692 done 693 \cd $HERE 694} 695 696function mm() 697{ 698 local T=$(gettop) 699 local DRV=$(getdriver $T) 700 # If we're sitting in the root of the build tree, just do a 701 # normal make. 702 if [ -f build/core/envsetup.mk -a -f Makefile ]; then 703 $DRV make $@ 704 else 705 # Find the closest Android.mk file. 706 local M=$(findmakefile) 707 local MODULES= 708 local GET_INSTALL_PATH= 709 local ARGS= 710 # Remove the path to top as the makefilepath needs to be relative 711 local M=`echo $M|sed 's:'$T'/::'` 712 if [ ! "$T" ]; then 713 echo "Couldn't locate the top of the tree. Try setting TOP." 714 return 1 715 elif [ ! "$M" ]; then 716 echo "Couldn't locate a makefile from the current directory." 717 return 1 718 else 719 for ARG in $@; do 720 case $ARG in 721 GET-INSTALL-PATH) GET_INSTALL_PATH=$ARG;; 722 esac 723 done 724 if [ -n "$GET_INSTALL_PATH" ]; then 725 MODULES= 726 ARGS=GET-INSTALL-PATH 727 else 728 MODULES=all_modules 729 ARGS=$@ 730 fi 731 ONE_SHOT_MAKEFILE=$M $DRV make -C $T -f build/core/main.mk $MODULES $ARGS 732 fi 733 fi 734} 735 736function mmm() 737{ 738 local T=$(gettop) 739 local DRV=$(getdriver $T) 740 if [ "$T" ]; then 741 local MAKEFILE= 742 local MODULES= 743 local ARGS= 744 local DIR TO_CHOP 745 local GET_INSTALL_PATH= 746 local DASH_ARGS=$(echo "$@" | awk -v RS=" " -v ORS=" " '/^-.*$/') 747 local DIRS=$(echo "$@" | awk -v RS=" " -v ORS=" " '/^[^-].*$/') 748 for DIR in $DIRS ; do 749 MODULES=`echo $DIR | sed -n -e 's/.*:\(.*$\)/\1/p' | sed 's/,/ /'` 750 if [ "$MODULES" = "" ]; then 751 MODULES=all_modules 752 fi 753 DIR=`echo $DIR | sed -e 's/:.*//' -e 's:/$::'` 754 if [ -f $DIR/Android.mk ]; then 755 local TO_CHOP=`(\cd -P -- $T && pwd -P) | wc -c | tr -d ' '` 756 local TO_CHOP=`expr $TO_CHOP + 1` 757 local START=`PWD= /bin/pwd` 758 local MFILE=`echo $START | cut -c${TO_CHOP}-` 759 if [ "$MFILE" = "" ] ; then 760 MFILE=$DIR/Android.mk 761 else 762 MFILE=$MFILE/$DIR/Android.mk 763 fi 764 MAKEFILE="$MAKEFILE $MFILE" 765 else 766 case $DIR in 767 showcommands | snod | dist | incrementaljavac) ARGS="$ARGS $DIR";; 768 GET-INSTALL-PATH) GET_INSTALL_PATH=$DIR;; 769 *) echo "No Android.mk in $DIR."; return 1;; 770 esac 771 fi 772 done 773 if [ -n "$GET_INSTALL_PATH" ]; then 774 ARGS=$GET_INSTALL_PATH 775 MODULES= 776 fi 777 ONE_SHOT_MAKEFILE="$MAKEFILE" $DRV make -C $T -f build/core/main.mk $DASH_ARGS $MODULES $ARGS 778 else 779 echo "Couldn't locate the top of the tree. Try setting TOP." 780 return 1 781 fi 782} 783 784function mma() 785{ 786 local T=$(gettop) 787 local DRV=$(getdriver $T) 788 if [ -f build/core/envsetup.mk -a -f Makefile ]; then 789 $DRV make $@ 790 else 791 if [ ! "$T" ]; then 792 echo "Couldn't locate the top of the tree. Try setting TOP." 793 return 1 794 fi 795 local MY_PWD=`PWD= /bin/pwd|sed 's:'$T'/::'` 796 $DRV make -C $T -f build/core/main.mk $@ all_modules BUILD_MODULES_IN_PATHS="$MY_PWD" 797 fi 798} 799 800function mmma() 801{ 802 local T=$(gettop) 803 local DRV=$(getdriver $T) 804 if [ "$T" ]; then 805 local DASH_ARGS=$(echo "$@" | awk -v RS=" " -v ORS=" " '/^-.*$/') 806 local DIRS=$(echo "$@" | awk -v RS=" " -v ORS=" " '/^[^-].*$/') 807 local MY_PWD=`PWD= /bin/pwd` 808 if [ "$MY_PWD" = "$T" ]; then 809 MY_PWD= 810 else 811 MY_PWD=`echo $MY_PWD|sed 's:'$T'/::'` 812 fi 813 local DIR= 814 local MODULE_PATHS= 815 local ARGS= 816 for DIR in $DIRS ; do 817 if [ -d $DIR ]; then 818 if [ "$MY_PWD" = "" ]; then 819 MODULE_PATHS="$MODULE_PATHS $DIR" 820 else 821 MODULE_PATHS="$MODULE_PATHS $MY_PWD/$DIR" 822 fi 823 else 824 case $DIR in 825 showcommands | snod | dist | incrementaljavac) ARGS="$ARGS $DIR";; 826 *) echo "Couldn't find directory $DIR"; return 1;; 827 esac 828 fi 829 done 830 $DRV make -C $T -f build/core/main.mk $DASH_ARGS $ARGS all_modules BUILD_MODULES_IN_PATHS="$MODULE_PATHS" 831 else 832 echo "Couldn't locate the top of the tree. Try setting TOP." 833 return 1 834 fi 835} 836 837function croot() 838{ 839 T=$(gettop) 840 if [ "$T" ]; then 841 \cd $(gettop) 842 else 843 echo "Couldn't locate the top of the tree. Try setting TOP." 844 fi 845} 846 847function cproj() 848{ 849 TOPFILE=build/core/envsetup.mk 850 local HERE=$PWD 851 T= 852 while [ \( ! \( -f $TOPFILE \) \) -a \( $PWD != "/" \) ]; do 853 T=$PWD 854 if [ -f "$T/Android.mk" ]; then 855 \cd $T 856 return 857 fi 858 \cd .. 859 done 860 \cd $HERE 861 echo "can't find Android.mk" 862} 863 864# simplified version of ps; output in the form 865# <pid> <procname> 866function qpid() { 867 local prepend='' 868 local append='' 869 if [ "$1" = "--exact" ]; then 870 prepend=' ' 871 append='$' 872 shift 873 elif [ "$1" = "--help" -o "$1" = "-h" ]; then 874 echo "usage: qpid [[--exact] <process name|pid>" 875 return 255 876 fi 877 878 local EXE="$1" 879 if [ "$EXE" ] ; then 880 qpid | \grep "$prepend$EXE$append" 881 else 882 adb shell ps \ 883 | tr -d '\r' \ 884 | sed -e 1d -e 's/^[^ ]* *\([0-9]*\).* \([^ ]*\)$/\1 \2/' 885 fi 886} 887 888function pid() 889{ 890 local prepend='' 891 local append='' 892 if [ "$1" = "--exact" ]; then 893 prepend=' ' 894 append='$' 895 shift 896 fi 897 local EXE="$1" 898 if [ "$EXE" ] ; then 899 local PID=`adb shell ps \ 900 | tr -d '\r' \ 901 | \grep "$prepend$EXE$append" \ 902 | sed -e 's/^[^ ]* *\([0-9]*\).*$/\1/'` 903 echo "$PID" 904 else 905 echo "usage: pid [--exact] <process name>" 906 return 255 907 fi 908} 909 910# coredump_setup - enable core dumps globally for any process 911# that has the core-file-size limit set correctly 912# 913# NOTE: You must call also coredump_enable for a specific process 914# if its core-file-size limit is not set already. 915# NOTE: Core dumps are written to ramdisk; they will not survive a reboot! 916 917function coredump_setup() 918{ 919 echo "Getting root..."; 920 adb root; 921 adb wait-for-device; 922 923 echo "Remounting root parition read-write..."; 924 adb shell mount -w -o remount -t rootfs rootfs; 925 sleep 1; 926 adb wait-for-device; 927 adb shell mkdir -p /cores; 928 adb shell mount -t tmpfs tmpfs /cores; 929 adb shell chmod 0777 /cores; 930 931 echo "Granting SELinux permission to dump in /cores..."; 932 adb shell restorecon -R /cores; 933 934 echo "Set core pattern."; 935 adb shell 'echo /cores/core.%p > /proc/sys/kernel/core_pattern'; 936 937 echo "Done." 938} 939 940# coredump_enable - enable core dumps for the specified process 941# $1 = PID of process (e.g., $(pid mediaserver)) 942# 943# NOTE: coredump_setup must have been called as well for a core 944# dump to actually be generated. 945 946function coredump_enable() 947{ 948 local PID=$1; 949 if [ -z "$PID" ]; then 950 printf "Expecting a PID!\n"; 951 return; 952 fi; 953 echo "Setting core limit for $PID to infinite..."; 954 adb shell prlimit $PID 4 -1 -1 955} 956 957# core - send SIGV and pull the core for process 958# $1 = PID of process (e.g., $(pid mediaserver)) 959# 960# NOTE: coredump_setup must be called once per boot for core dumps to be 961# enabled globally. 962 963function core() 964{ 965 local PID=$1; 966 967 if [ -z "$PID" ]; then 968 printf "Expecting a PID!\n"; 969 return; 970 fi; 971 972 local CORENAME=core.$PID; 973 local COREPATH=/cores/$CORENAME; 974 local SIG=SEGV; 975 976 coredump_enable $1; 977 978 local done=0; 979 while [ $(adb shell "[ -d /proc/$PID ] && echo -n yes") ]; do 980 printf "\tSending SIG%s to %d...\n" $SIG $PID; 981 adb shell kill -$SIG $PID; 982 sleep 1; 983 done; 984 985 adb shell "while [ ! -f $COREPATH ] ; do echo waiting for $COREPATH to be generated; sleep 1; done" 986 echo "Done: core is under $COREPATH on device."; 987} 988 989# systemstack - dump the current stack trace of all threads in the system process 990# to the usual ANR traces file 991function systemstack() 992{ 993 stacks system_server 994} 995 996function stacks() 997{ 998 if [[ $1 =~ ^[0-9]+$ ]] ; then 999 local PID="$1" 1000 elif [ "$1" ] ; then 1001 local PIDLIST="$(pid $1)" 1002 if [[ $PIDLIST =~ ^[0-9]+$ ]] ; then 1003 local PID="$PIDLIST" 1004 elif [ "$PIDLIST" ] ; then 1005 echo "more than one process: $1" 1006 else 1007 echo "no such process: $1" 1008 fi 1009 else 1010 echo "usage: stacks [pid|process name]" 1011 fi 1012 1013 if [ "$PID" ] ; then 1014 # Determine whether the process is native 1015 if adb shell ls -l /proc/$PID/exe | grep -q /system/bin/app_process ; then 1016 # Dump stacks of Dalvik process 1017 local TRACES=/data/anr/traces.txt 1018 local ORIG=/data/anr/traces.orig 1019 local TMP=/data/anr/traces.tmp 1020 1021 # Keep original traces to avoid clobbering 1022 adb shell mv $TRACES $ORIG 1023 1024 # Make sure we have a usable file 1025 adb shell touch $TRACES 1026 adb shell chmod 666 $TRACES 1027 1028 # Dump stacks and wait for dump to finish 1029 adb shell kill -3 $PID 1030 adb shell notify $TRACES >/dev/null 1031 1032 # Restore original stacks, and show current output 1033 adb shell mv $TRACES $TMP 1034 adb shell mv $ORIG $TRACES 1035 adb shell cat $TMP 1036 else 1037 # Dump stacks of native process 1038 local USE64BIT="$(is64bit $PID)" 1039 adb shell debuggerd$USE64BIT -b $PID 1040 fi 1041 fi 1042} 1043 1044# Read the ELF header from /proc/$PID/exe to determine if the process is 1045# 64-bit. 1046function is64bit() 1047{ 1048 local PID="$1" 1049 if [ "$PID" ] ; then 1050 if [[ "$(adb shell cat /proc/$PID/exe | xxd -l 1 -s 4 -ps)" -eq "02" ]] ; then 1051 echo "64" 1052 else 1053 echo "" 1054 fi 1055 else 1056 echo "" 1057 fi 1058} 1059 1060case `uname -s` in 1061 Darwin) 1062 function sgrep() 1063 { 1064 find -E . -name .repo -prune -o -name .git -prune -o -type f -iregex '.*\.(c|h|cc|cpp|S|java|xml|sh|mk|aidl)' -print0 | xargs -0 grep --color -n "$@" 1065 } 1066 1067 ;; 1068 *) 1069 function sgrep() 1070 { 1071 find . -name .repo -prune -o -name .git -prune -o -type f -iregex '.*\.\(c\|h\|cc\|cpp\|S\|java\|xml\|sh\|mk\|aidl\)' -print0 | xargs -0 grep --color -n "$@" 1072 } 1073 ;; 1074esac 1075 1076function gettargetarch 1077{ 1078 get_build_var TARGET_ARCH 1079} 1080 1081function ggrep() 1082{ 1083 find . -name .repo -prune -o -name .git -prune -o -name out -prune -o -type f -name "*\.gradle" -print0 | xargs -0 grep --color -n "$@" 1084} 1085 1086function jgrep() 1087{ 1088 find . -name .repo -prune -o -name .git -prune -o -name out -prune -o -type f -name "*\.java" -print0 | xargs -0 grep --color -n "$@" 1089} 1090 1091function cgrep() 1092{ 1093 find . -name .repo -prune -o -name .git -prune -o -name out -prune -o -type f \( -name '*.c' -o -name '*.cc' -o -name '*.cpp' -o -name '*.h' -o -name '*.hpp' \) -print0 | xargs -0 grep --color -n "$@" 1094} 1095 1096function resgrep() 1097{ 1098 for dir in `find . -name .repo -prune -o -name .git -prune -o -name out -prune -o -name res -type d`; do find $dir -type f -name '*\.xml' -print0 | xargs -0 grep --color -n "$@"; done; 1099} 1100 1101function mangrep() 1102{ 1103 find . -name .repo -prune -o -name .git -prune -o -path ./out -prune -o -type f -name 'AndroidManifest.xml' -print0 | xargs -0 grep --color -n "$@" 1104} 1105 1106function sepgrep() 1107{ 1108 find . -name .repo -prune -o -name .git -prune -o -path ./out -prune -o -name sepolicy -type d -print0 | xargs -0 grep --color -n -r --exclude-dir=\.git "$@" 1109} 1110 1111case `uname -s` in 1112 Darwin) 1113 function mgrep() 1114 { 1115 find -E . -name .repo -prune -o -name .git -prune -o -path ./out -prune -o -type f -iregex '.*/(Makefile|Makefile\..*|.*\.make|.*\.mak|.*\.mk)' -print0 | xargs -0 grep --color -n "$@" 1116 } 1117 1118 function treegrep() 1119 { 1120 find -E . -name .repo -prune -o -name .git -prune -o -type f -iregex '.*\.(c|h|cpp|S|java|xml)' -print0 | xargs -0 grep --color -n -i "$@" 1121 } 1122 1123 ;; 1124 *) 1125 function mgrep() 1126 { 1127 find . -name .repo -prune -o -name .git -prune -o -path ./out -prune -o -regextype posix-egrep -iregex '(.*\/Makefile|.*\/Makefile\..*|.*\.make|.*\.mak|.*\.mk)' -type f -print0 | xargs -0 grep --color -n "$@" 1128 } 1129 1130 function treegrep() 1131 { 1132 find . -name .repo -prune -o -name .git -prune -o -regextype posix-egrep -iregex '.*\.(c|h|cpp|S|java|xml)' -type f -print0 | xargs -0 grep --color -n -i "$@" 1133 } 1134 1135 ;; 1136esac 1137 1138function getprebuilt 1139{ 1140 get_abs_build_var ANDROID_PREBUILTS 1141} 1142 1143function tracedmdump() 1144{ 1145 T=$(gettop) 1146 if [ ! "$T" ]; then 1147 echo "Couldn't locate the top of the tree. Try setting TOP." 1148 return 1149 fi 1150 local prebuiltdir=$(getprebuilt) 1151 local arch=$(gettargetarch) 1152 local KERNEL=$T/prebuilts/qemu-kernel/$arch/vmlinux-qemu 1153 1154 local TRACE=$1 1155 if [ ! "$TRACE" ] ; then 1156 echo "usage: tracedmdump tracename" 1157 return 1158 fi 1159 1160 if [ ! -r "$KERNEL" ] ; then 1161 echo "Error: cannot find kernel: '$KERNEL'" 1162 return 1163 fi 1164 1165 local BASETRACE=$(basename $TRACE) 1166 if [ "$BASETRACE" = "$TRACE" ] ; then 1167 TRACE=$ANDROID_PRODUCT_OUT/traces/$TRACE 1168 fi 1169 1170 echo "post-processing traces..." 1171 rm -f $TRACE/qtrace.dexlist 1172 post_trace $TRACE 1173 if [ $? -ne 0 ]; then 1174 echo "***" 1175 echo "*** Error: malformed trace. Did you remember to exit the emulator?" 1176 echo "***" 1177 return 1178 fi 1179 echo "generating dexlist output..." 1180 /bin/ls $ANDROID_PRODUCT_OUT/system/framework/*.jar $ANDROID_PRODUCT_OUT/system/app/*.apk $ANDROID_PRODUCT_OUT/data/app/*.apk 2>/dev/null | xargs dexlist > $TRACE/qtrace.dexlist 1181 echo "generating dmtrace data..." 1182 q2dm -r $ANDROID_PRODUCT_OUT/symbols $TRACE $KERNEL $TRACE/dmtrace || return 1183 echo "generating html file..." 1184 dmtracedump -h $TRACE/dmtrace >| $TRACE/dmtrace.html || return 1185 echo "done, see $TRACE/dmtrace.html for details" 1186 echo "or run:" 1187 echo " traceview $TRACE/dmtrace" 1188} 1189 1190# communicate with a running device or emulator, set up necessary state, 1191# and run the hat command. 1192function runhat() 1193{ 1194 # process standard adb options 1195 local adbTarget="" 1196 if [ "$1" = "-d" -o "$1" = "-e" ]; then 1197 adbTarget=$1 1198 shift 1 1199 elif [ "$1" = "-s" ]; then 1200 adbTarget="$1 $2" 1201 shift 2 1202 fi 1203 local adbOptions=${adbTarget} 1204 #echo adbOptions = ${adbOptions} 1205 1206 # runhat options 1207 local targetPid=$1 1208 1209 if [ "$targetPid" = "" ]; then 1210 echo "Usage: runhat [ -d | -e | -s serial ] target-pid" 1211 return 1212 fi 1213 1214 # confirm hat is available 1215 if [ -z $(which hat) ]; then 1216 echo "hat is not available in this configuration." 1217 return 1218 fi 1219 1220 # issue "am" command to cause the hprof dump 1221 local devFile=/data/local/tmp/hprof-$targetPid 1222 echo "Poking $targetPid and waiting for data..." 1223 echo "Storing data at $devFile" 1224 adb ${adbOptions} shell am dumpheap $targetPid $devFile 1225 echo "Press enter when logcat shows \"hprof: heap dump completed\"" 1226 echo -n "> " 1227 read 1228 1229 local localFile=/tmp/$$-hprof 1230 1231 echo "Retrieving file $devFile..." 1232 adb ${adbOptions} pull $devFile $localFile 1233 1234 adb ${adbOptions} shell rm $devFile 1235 1236 echo "Running hat on $localFile" 1237 echo "View the output by pointing your browser at http://localhost:7000/" 1238 echo "" 1239 hat -JXmx512m $localFile 1240} 1241 1242function getbugreports() 1243{ 1244 local reports=(`adb shell ls /sdcard/bugreports | tr -d '\r'`) 1245 1246 if [ ! "$reports" ]; then 1247 echo "Could not locate any bugreports." 1248 return 1249 fi 1250 1251 local report 1252 for report in ${reports[@]} 1253 do 1254 echo "/sdcard/bugreports/${report}" 1255 adb pull /sdcard/bugreports/${report} ${report} 1256 gunzip ${report} 1257 done 1258} 1259 1260function getsdcardpath() 1261{ 1262 adb ${adbOptions} shell echo -n \$\{EXTERNAL_STORAGE\} 1263} 1264 1265function getscreenshotpath() 1266{ 1267 echo "$(getsdcardpath)/Pictures/Screenshots" 1268} 1269 1270function getlastscreenshot() 1271{ 1272 local screenshot_path=$(getscreenshotpath) 1273 local screenshot=`adb ${adbOptions} ls ${screenshot_path} | grep Screenshot_[0-9-]*.*\.png | sort -rk 3 | cut -d " " -f 4 | head -n 1` 1274 if [ "$screenshot" = "" ]; then 1275 echo "No screenshots found." 1276 return 1277 fi 1278 echo "${screenshot}" 1279 adb ${adbOptions} pull ${screenshot_path}/${screenshot} 1280} 1281 1282function startviewserver() 1283{ 1284 local port=4939 1285 if [ $# -gt 0 ]; then 1286 port=$1 1287 fi 1288 adb shell service call window 1 i32 $port 1289} 1290 1291function stopviewserver() 1292{ 1293 adb shell service call window 2 1294} 1295 1296function isviewserverstarted() 1297{ 1298 adb shell service call window 3 1299} 1300 1301function key_home() 1302{ 1303 adb shell input keyevent 3 1304} 1305 1306function key_back() 1307{ 1308 adb shell input keyevent 4 1309} 1310 1311function key_menu() 1312{ 1313 adb shell input keyevent 82 1314} 1315 1316function smoketest() 1317{ 1318 if [ ! "$ANDROID_PRODUCT_OUT" ]; then 1319 echo "Couldn't locate output files. Try running 'lunch' first." >&2 1320 return 1321 fi 1322 T=$(gettop) 1323 if [ ! "$T" ]; then 1324 echo "Couldn't locate the top of the tree. Try setting TOP." >&2 1325 return 1326 fi 1327 1328 (\cd "$T" && mmm tests/SmokeTest) && 1329 adb uninstall com.android.smoketest > /dev/null && 1330 adb uninstall com.android.smoketest.tests > /dev/null && 1331 adb install $ANDROID_PRODUCT_OUT/data/app/SmokeTestApp.apk && 1332 adb install $ANDROID_PRODUCT_OUT/data/app/SmokeTest.apk && 1333 adb shell am instrument -w com.android.smoketest.tests/android.test.InstrumentationTestRunner 1334} 1335 1336# simple shortcut to the runtest command 1337function runtest() 1338{ 1339 T=$(gettop) 1340 if [ ! "$T" ]; then 1341 echo "Couldn't locate the top of the tree. Try setting TOP." >&2 1342 return 1343 fi 1344 ("$T"/development/testrunner/runtest.py $@) 1345} 1346 1347function godir () { 1348 if [[ -z "$1" ]]; then 1349 echo "Usage: godir <regex>" 1350 return 1351 fi 1352 T=$(gettop) 1353 if [[ ! -f $T/filelist ]]; then 1354 echo -n "Creating index..." 1355 (\cd $T; find . -wholename ./out -prune -o -wholename ./.repo -prune -o -type f > filelist) 1356 echo " Done" 1357 echo "" 1358 fi 1359 local lines 1360 lines=($(\grep "$1" $T/filelist | sed -e 's/\/[^/]*$//' | sort | uniq)) 1361 if [[ ${#lines[@]} = 0 ]]; then 1362 echo "Not found" 1363 return 1364 fi 1365 local pathname 1366 local choice 1367 if [[ ${#lines[@]} > 1 ]]; then 1368 while [[ -z "$pathname" ]]; do 1369 local index=1 1370 local line 1371 for line in ${lines[@]}; do 1372 printf "%6s %s\n" "[$index]" $line 1373 index=$(($index + 1)) 1374 done 1375 echo 1376 echo -n "Select one: " 1377 unset choice 1378 read choice 1379 if [[ $choice -gt ${#lines[@]} || $choice -lt 1 ]]; then 1380 echo "Invalid choice" 1381 continue 1382 fi 1383 pathname=${lines[$(($choice-1))]} 1384 done 1385 else 1386 pathname=${lines[0]} 1387 fi 1388 \cd $T/$pathname 1389} 1390 1391# Force JAVA_HOME to point to java 1.7 if it isn't already set. 1392# 1393# Note that the MacOS path for java 1.7 includes a minor revision number (sigh). 1394# For some reason, installing the JDK doesn't make it show up in the 1395# JavaVM.framework/Versions/1.7/ folder. 1396function set_java_home() { 1397 # Clear the existing JAVA_HOME value if we set it ourselves, so that 1398 # we can reset it later, depending on the version of java the build 1399 # system needs. 1400 # 1401 # If we don't do this, the JAVA_HOME value set by the first call to 1402 # build/envsetup.sh will persist forever. 1403 if [ -n "$ANDROID_SET_JAVA_HOME" ]; then 1404 export JAVA_HOME="" 1405 fi 1406 1407 if [ ! "$JAVA_HOME" ]; then 1408 case `uname -s` in 1409 Darwin) 1410 export JAVA_HOME=$(/usr/libexec/java_home -v 1.7) 1411 ;; 1412 *) 1413 export JAVA_HOME=/usr/lib/jvm/java-7-openjdk-amd64 1414 ;; 1415 esac 1416 1417 # Keep track of the fact that we set JAVA_HOME ourselves, so that 1418 # we can change it on the next envsetup.sh, if required. 1419 export ANDROID_SET_JAVA_HOME=true 1420 fi 1421} 1422 1423# Print colored exit condition 1424function pez { 1425 "$@" 1426 local retval=$? 1427 if [ $retval -ne 0 ] 1428 then 1429 echo -e "\e[0;31mFAILURE\e[00m" 1430 else 1431 echo -e "\e[0;32mSUCCESS\e[00m" 1432 fi 1433 return $retval 1434} 1435 1436function get_make_command() 1437{ 1438 echo command make 1439} 1440 1441function make() 1442{ 1443 local start_time=$(date +"%s") 1444 $(get_make_command) "$@" 1445 local ret=$? 1446 local end_time=$(date +"%s") 1447 local tdiff=$(($end_time-$start_time)) 1448 local hours=$(($tdiff / 3600 )) 1449 local mins=$((($tdiff % 3600) / 60)) 1450 local secs=$(($tdiff % 60)) 1451 local ncolors=$(tput colors 2>/dev/null) 1452 if [ -n "$ncolors" ] && [ $ncolors -ge 8 ]; then 1453 color_failed="\e[0;31m" 1454 color_success="\e[0;32m" 1455 color_reset="\e[00m" 1456 else 1457 color_failed="" 1458 color_success="" 1459 color_reset="" 1460 fi 1461 echo 1462 if [ $ret -eq 0 ] ; then 1463 echo -n -e "${color_success}#### make completed successfully " 1464 else 1465 echo -n -e "${color_failed}#### make failed to build some targets " 1466 fi 1467 if [ $hours -gt 0 ] ; then 1468 printf "(%02g:%02g:%02g (hh:mm:ss))" $hours $mins $secs 1469 elif [ $mins -gt 0 ] ; then 1470 printf "(%02g:%02g (mm:ss))" $mins $secs 1471 elif [ $secs -gt 0 ] ; then 1472 printf "(%s seconds)" $secs 1473 fi 1474 echo -e " ####${color_reset}" 1475 echo 1476 return $ret 1477} 1478 1479if [ "x$SHELL" != "x/bin/bash" ]; then 1480 case `ps -o command -p $$` in 1481 *bash*) 1482 ;; 1483 *) 1484 echo "WARNING: Only bash is supported, use of other shell would lead to erroneous results" 1485 ;; 1486 esac 1487fi 1488 1489# Execute the contents of any vendorsetup.sh files we can find. 1490for f in `test -d device && find -L device -maxdepth 4 -name 'vendorsetup.sh' 2> /dev/null` \ 1491 `test -d vendor && find -L vendor -maxdepth 4 -name 'vendorsetup.sh' 2> /dev/null` 1492do 1493 echo "including $f" 1494 . $f 1495done 1496unset f 1497 1498addcompletions 1499