1 function hmm() { 2 cat <<EOF 3 Invoke ". 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 22 Environemnt 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 27 Look at the source to view more functions. The complete list is: 28 EOF 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. 39 function 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. 51 function 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 63 function 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 78 VARIANT_CHOICES=(user userdebug eng) 79 80 # check to see if the supplied variant is valid 81 function 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 93 function 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:$T/external/selinux/prebuilts/bin 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 221 function 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 231 function 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 244 function set_sequence_number() 245 { 246 export BUILD_ENV_SEQUENCE_NUMBER=10 247 } 248 249 function 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 264 function 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 287 function 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 # 345 function 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 383 function 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 430 function 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. 449 unset LUNCH_MENU_CHOICES 450 function 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 463 add_lunch_combo aosp_arm-eng 464 add_lunch_combo aosp_arm64-eng 465 add_lunch_combo aosp_mips-eng 466 add_lunch_combo aosp_mips64-eng 467 add_lunch_combo aosp_x86-eng 468 add_lunch_combo aosp_x86_64-eng 469 470 function 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 489 function 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. 563 function _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 } 573 complete -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) 577 function 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 626 function 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) 654 function 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 667 function 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 679 function 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 696 function 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 736 function 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 784 function 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 800 function 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 837 function 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 847 function 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> 866 function 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 888 function 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 917 function 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 946 function 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 963 function 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 991 function systemstack() 992 { 993 stacks system_server 994 } 995 996 function 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. 1046 function 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 1060 case `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 ;; 1074 esac 1075 1076 function gettargetarch 1077 { 1078 get_build_var TARGET_ARCH 1079 } 1080 1081 function 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 1086 function 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 1091 function 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 1096 function 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 1101 function 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 1106 function 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 1111 function rcgrep() 1112 { 1113 find . -name .repo -prune -o -name .git -prune -o -name out -prune -o -type f -name "*\.rc*" -print0 | xargs -0 grep --color -n "$@" 1114 } 1115 1116 case `uname -s` in 1117 Darwin) 1118 function mgrep() 1119 { 1120 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 "$@" 1121 } 1122 1123 function treegrep() 1124 { 1125 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 "$@" 1126 } 1127 1128 ;; 1129 *) 1130 function mgrep() 1131 { 1132 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 "$@" 1133 } 1134 1135 function treegrep() 1136 { 1137 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 "$@" 1138 } 1139 1140 ;; 1141 esac 1142 1143 function getprebuilt 1144 { 1145 get_abs_build_var ANDROID_PREBUILTS 1146 } 1147 1148 function tracedmdump() 1149 { 1150 T=$(gettop) 1151 if [ ! "$T" ]; then 1152 echo "Couldn't locate the top of the tree. Try setting TOP." 1153 return 1154 fi 1155 local prebuiltdir=$(getprebuilt) 1156 local arch=$(gettargetarch) 1157 local KERNEL=$T/prebuilts/qemu-kernel/$arch/vmlinux-qemu 1158 1159 local TRACE=$1 1160 if [ ! "$TRACE" ] ; then 1161 echo "usage: tracedmdump tracename" 1162 return 1163 fi 1164 1165 if [ ! -r "$KERNEL" ] ; then 1166 echo "Error: cannot find kernel: '$KERNEL'" 1167 return 1168 fi 1169 1170 local BASETRACE=$(basename $TRACE) 1171 if [ "$BASETRACE" = "$TRACE" ] ; then 1172 TRACE=$ANDROID_PRODUCT_OUT/traces/$TRACE 1173 fi 1174 1175 echo "post-processing traces..." 1176 rm -f $TRACE/qtrace.dexlist 1177 post_trace $TRACE 1178 if [ $? -ne 0 ]; then 1179 echo "***" 1180 echo "*** Error: malformed trace. Did you remember to exit the emulator?" 1181 echo "***" 1182 return 1183 fi 1184 echo "generating dexlist output..." 1185 /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 1186 echo "generating dmtrace data..." 1187 q2dm -r $ANDROID_PRODUCT_OUT/symbols $TRACE $KERNEL $TRACE/dmtrace || return 1188 echo "generating html file..." 1189 dmtracedump -h $TRACE/dmtrace >| $TRACE/dmtrace.html || return 1190 echo "done, see $TRACE/dmtrace.html for details" 1191 echo "or run:" 1192 echo " traceview $TRACE/dmtrace" 1193 } 1194 1195 # communicate with a running device or emulator, set up necessary state, 1196 # and run the hat command. 1197 function runhat() 1198 { 1199 # process standard adb options 1200 local adbTarget="" 1201 if [ "$1" = "-d" -o "$1" = "-e" ]; then 1202 adbTarget=$1 1203 shift 1 1204 elif [ "$1" = "-s" ]; then 1205 adbTarget="$1 $2" 1206 shift 2 1207 fi 1208 local adbOptions=${adbTarget} 1209 #echo adbOptions = ${adbOptions} 1210 1211 # runhat options 1212 local targetPid=$1 1213 1214 if [ "$targetPid" = "" ]; then 1215 echo "Usage: runhat [ -d | -e | -s serial ] target-pid" 1216 return 1217 fi 1218 1219 # confirm hat is available 1220 if [ -z $(which hat) ]; then 1221 echo "hat is not available in this configuration." 1222 return 1223 fi 1224 1225 # issue "am" command to cause the hprof dump 1226 local devFile=/data/local/tmp/hprof-$targetPid 1227 echo "Poking $targetPid and waiting for data..." 1228 echo "Storing data at $devFile" 1229 adb ${adbOptions} shell am dumpheap $targetPid $devFile 1230 echo "Press enter when logcat shows \"hprof: heap dump completed\"" 1231 echo -n "> " 1232 read 1233 1234 local localFile=/tmp/$$-hprof 1235 1236 echo "Retrieving file $devFile..." 1237 adb ${adbOptions} pull $devFile $localFile 1238 1239 adb ${adbOptions} shell rm $devFile 1240 1241 echo "Running hat on $localFile" 1242 echo "View the output by pointing your browser at http://localhost:7000/" 1243 echo "" 1244 hat -JXmx512m $localFile 1245 } 1246 1247 function getbugreports() 1248 { 1249 local reports=(`adb shell ls /sdcard/bugreports | tr -d '\r'`) 1250 1251 if [ ! "$reports" ]; then 1252 echo "Could not locate any bugreports." 1253 return 1254 fi 1255 1256 local report 1257 for report in ${reports[@]} 1258 do 1259 echo "/sdcard/bugreports/${report}" 1260 adb pull /sdcard/bugreports/${report} ${report} 1261 gunzip ${report} 1262 done 1263 } 1264 1265 function getsdcardpath() 1266 { 1267 adb ${adbOptions} shell echo -n \$\{EXTERNAL_STORAGE\} 1268 } 1269 1270 function getscreenshotpath() 1271 { 1272 echo "$(getsdcardpath)/Pictures/Screenshots" 1273 } 1274 1275 function getlastscreenshot() 1276 { 1277 local screenshot_path=$(getscreenshotpath) 1278 local screenshot=`adb ${adbOptions} ls ${screenshot_path} | grep Screenshot_[0-9-]*.*\.png | sort -rk 3 | cut -d " " -f 4 | head -n 1` 1279 if [ "$screenshot" = "" ]; then 1280 echo "No screenshots found." 1281 return 1282 fi 1283 echo "${screenshot}" 1284 adb ${adbOptions} pull ${screenshot_path}/${screenshot} 1285 } 1286 1287 function startviewserver() 1288 { 1289 local port=4939 1290 if [ $# -gt 0 ]; then 1291 port=$1 1292 fi 1293 adb shell service call window 1 i32 $port 1294 } 1295 1296 function stopviewserver() 1297 { 1298 adb shell service call window 2 1299 } 1300 1301 function isviewserverstarted() 1302 { 1303 adb shell service call window 3 1304 } 1305 1306 function key_home() 1307 { 1308 adb shell input keyevent 3 1309 } 1310 1311 function key_back() 1312 { 1313 adb shell input keyevent 4 1314 } 1315 1316 function key_menu() 1317 { 1318 adb shell input keyevent 82 1319 } 1320 1321 function smoketest() 1322 { 1323 if [ ! "$ANDROID_PRODUCT_OUT" ]; then 1324 echo "Couldn't locate output files. Try running 'lunch' first." >&2 1325 return 1326 fi 1327 T=$(gettop) 1328 if [ ! "$T" ]; then 1329 echo "Couldn't locate the top of the tree. Try setting TOP." >&2 1330 return 1331 fi 1332 1333 (\cd "$T" && mmm tests/SmokeTest) && 1334 adb uninstall com.android.smoketest > /dev/null && 1335 adb uninstall com.android.smoketest.tests > /dev/null && 1336 adb install $ANDROID_PRODUCT_OUT/data/app/SmokeTestApp.apk && 1337 adb install $ANDROID_PRODUCT_OUT/data/app/SmokeTest.apk && 1338 adb shell am instrument -w com.android.smoketest.tests/android.test.InstrumentationTestRunner 1339 } 1340 1341 # simple shortcut to the runtest command 1342 function runtest() 1343 { 1344 T=$(gettop) 1345 if [ ! "$T" ]; then 1346 echo "Couldn't locate the top of the tree. Try setting TOP." >&2 1347 return 1348 fi 1349 ("$T"/development/testrunner/runtest.py $@) 1350 } 1351 1352 function godir () { 1353 if [[ -z "$1" ]]; then 1354 echo "Usage: godir <regex>" 1355 return 1356 fi 1357 T=$(gettop) 1358 if [[ ! -f $T/filelist ]]; then 1359 echo -n "Creating index..." 1360 (\cd $T; find . -wholename ./out -prune -o -wholename ./.repo -prune -o -type f > filelist) 1361 echo " Done" 1362 echo "" 1363 fi 1364 local lines 1365 lines=($(\grep "$1" $T/filelist | sed -e 's/\/[^/]*$//' | sort | uniq)) 1366 if [[ ${#lines[@]} = 0 ]]; then 1367 echo "Not found" 1368 return 1369 fi 1370 local pathname 1371 local choice 1372 if [[ ${#lines[@]} > 1 ]]; then 1373 while [[ -z "$pathname" ]]; do 1374 local index=1 1375 local line 1376 for line in ${lines[@]}; do 1377 printf "%6s %s\n" "[$index]" $line 1378 index=$(($index + 1)) 1379 done 1380 echo 1381 echo -n "Select one: " 1382 unset choice 1383 read choice 1384 if [[ $choice -gt ${#lines[@]} || $choice -lt 1 ]]; then 1385 echo "Invalid choice" 1386 continue 1387 fi 1388 pathname=${lines[$(($choice-1))]} 1389 done 1390 else 1391 pathname=${lines[0]} 1392 fi 1393 \cd $T/$pathname 1394 } 1395 1396 # Force JAVA_HOME to point to java 1.7 if it isn't already set. 1397 # 1398 # Note that the MacOS path for java 1.7 includes a minor revision number (sigh). 1399 # For some reason, installing the JDK doesn't make it show up in the 1400 # JavaVM.framework/Versions/1.7/ folder. 1401 function set_java_home() { 1402 # Clear the existing JAVA_HOME value if we set it ourselves, so that 1403 # we can reset it later, depending on the version of java the build 1404 # system needs. 1405 # 1406 # If we don't do this, the JAVA_HOME value set by the first call to 1407 # build/envsetup.sh will persist forever. 1408 if [ -n "$ANDROID_SET_JAVA_HOME" ]; then 1409 export JAVA_HOME="" 1410 fi 1411 1412 if [ ! "$JAVA_HOME" ]; then 1413 case `uname -s` in 1414 Darwin) 1415 export JAVA_HOME=$(/usr/libexec/java_home -v 1.7) 1416 ;; 1417 *) 1418 export JAVA_HOME=/usr/lib/jvm/java-7-openjdk-amd64 1419 ;; 1420 esac 1421 1422 # Keep track of the fact that we set JAVA_HOME ourselves, so that 1423 # we can change it on the next envsetup.sh, if required. 1424 export ANDROID_SET_JAVA_HOME=true 1425 fi 1426 } 1427 1428 # Print colored exit condition 1429 function pez { 1430 "$@" 1431 local retval=$? 1432 if [ $retval -ne 0 ] 1433 then 1434 echo -e "\e[0;31mFAILURE\e[00m" 1435 else 1436 echo -e "\e[0;32mSUCCESS\e[00m" 1437 fi 1438 return $retval 1439 } 1440 1441 function get_make_command() 1442 { 1443 echo command make 1444 } 1445 1446 function make() 1447 { 1448 local start_time=$(date +"%s") 1449 $(get_make_command) "$@" 1450 local ret=$? 1451 local end_time=$(date +"%s") 1452 local tdiff=$(($end_time-$start_time)) 1453 local hours=$(($tdiff / 3600 )) 1454 local mins=$((($tdiff % 3600) / 60)) 1455 local secs=$(($tdiff % 60)) 1456 local ncolors=$(tput colors 2>/dev/null) 1457 if [ -n "$ncolors" ] && [ $ncolors -ge 8 ]; then 1458 color_failed="\e[0;31m" 1459 color_success="\e[0;32m" 1460 color_reset="\e[00m" 1461 else 1462 color_failed="" 1463 color_success="" 1464 color_reset="" 1465 fi 1466 echo 1467 if [ $ret -eq 0 ] ; then 1468 echo -n -e "${color_success}#### make completed successfully " 1469 else 1470 echo -n -e "${color_failed}#### make failed to build some targets " 1471 fi 1472 if [ $hours -gt 0 ] ; then 1473 printf "(%02g:%02g:%02g (hh:mm:ss))" $hours $mins $secs 1474 elif [ $mins -gt 0 ] ; then 1475 printf "(%02g:%02g (mm:ss))" $mins $secs 1476 elif [ $secs -gt 0 ] ; then 1477 printf "(%s seconds)" $secs 1478 fi 1479 echo -e " ####${color_reset}" 1480 echo 1481 return $ret 1482 } 1483 1484 if [ "x$SHELL" != "x/bin/bash" ]; then 1485 case `ps -o command -p $$` in 1486 *bash*) 1487 ;; 1488 *) 1489 echo "WARNING: Only bash is supported, use of other shell would lead to erroneous results" 1490 ;; 1491 esac 1492 fi 1493 1494 # Execute the contents of any vendorsetup.sh files we can find. 1495 for f in `test -d device && find -L device -maxdepth 4 -name 'vendorsetup.sh' 2> /dev/null | sort` \ 1496 `test -d vendor && find -L vendor -maxdepth 4 -name 'vendorsetup.sh' 2> /dev/null | sort` 1497 do 1498 echo "including $f" 1499 . $f 1500 done 1501 unset f 1502 1503 addcompletions 1504