ndk-gdb revision 4cff650ddc3e0b2e56528b6aca56ef9171cac972
1a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner#!/bin/sh
2a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner#
3a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Copyright (C) 2010 The Android Open Source Project
4a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner#
5a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Licensed under the Apache License, Version 2.0 (the "License");
6a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# you may not use this file except in compliance with the License.
7a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# You may obtain a copy of the License at
8a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner#
9a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner#      http://www.apache.org/licenses/LICENSE-2.0
10a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner#
11a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Unless required by applicable law or agreed to in writing, software
12a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# distributed under the License is distributed on an "AS IS" BASIS,
13a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# See the License for the specific language governing permissions and
15a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# limitations under the License.
16a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner#
17a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
18a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# This wrapper script is used to launch a native debugging session
19a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# on a given NDK application. The application must be debuggable, i.e.
20a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# its android:debuggable attribute must be set to 'true' in the
21a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# <application> element of its manifest.
22a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner#
23a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# See docs/NDK-GDB.TXT for usage description. Essentially, you just
24a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# need to launch ndk-gdb from your application project directory
25a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# after doing ndk-build && ant install && <start-application-on-device>
26a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner#
27a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner. `dirname $0`/build/core/ndk-common.sh
28a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
29a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerforce_32bit_binaries
30a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
31a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfind_program ADB_CMD adb
32a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerADB_FLAGS=
33a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
34a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerAWK_CMD=awk
35a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
36a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerDEBUG_PORT=5039
37a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
38a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerPARAMETERS=
39a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerOPTION_HELP=no
40a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerOPTION_PROJECT=
41a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerOPTION_FORCE=no
42a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerOPTION_ADB=
43a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerOPTION_EXEC=
440b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' TurnerOPTION_START=no
450b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' TurnerOPTION_LAUNCH=
460b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' TurnerOPTION_LAUNCH_LIST=no
47a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
48a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnercheck_parameter ()
49a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner{
50a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    if [ -z "$2" ]; then
51a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        echo "ERROR: Missing parameter after option '$1'"
52a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        exit 1
53a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    fi
54a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner}
55a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
56a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnercheck_adb_flags ()
57a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner{
58a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    if [ -n "$ADB_FLAGS" ] ; then
59a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        echo "ERROR: Only one of -e, -d or -s <serial> can be used at the same time!"
60a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        exit 1
61a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    fi
62a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner}
63a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
64a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerget_build_var ()
65a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner{
66a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    if [ -z "$GNUMAKE" ] ; then
67a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        GNUMAKE=make
68a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    fi
69a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    $GNUMAKE --no-print-dir -f $ANDROID_NDK_ROOT/build/core/build-local.mk -C $PROJECT DUMP_$1
70a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner}
71a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
72a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerget_build_var_for_abi ()
73a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner{
74a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    if [ -z "$GNUMAKE" ] ; then
75a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        GNUMAKE=make
76a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    fi
77a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    $GNUMAKE --no-print-dir -f $ANDROID_NDK_ROOT/build/core/build-local.mk -C $PROJECT DUMP_$1 APP_ABI=$2
78a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner}
79a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
800b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner# Used to run an awk script on the manifest
810b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turnerrun_awk_manifest_script ()
820b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner{
830b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    $AWK_CMD -f $AWK_SCRIPTS/$1 $PROJECT/$MANIFEST
840b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner}
850b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner
86a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerVERBOSE=no
87a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerwhile [ -n "$1" ]; do
88a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    opt="$1"
89a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    optarg=`expr "x$opt" : 'x[^=]*=\(.*\)'`
90a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    case "$opt" in
91a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        --help|-h|-\?)
92a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            OPTION_HELP=yes
93a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            ;;
94a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        --verbose)
95a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            VERBOSE=yes
96a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            ;;
97a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        -s)
98a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            check_parameter $1 $2
99a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            check_adb_flags
100a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            ADB_FLAGS=" -s $2"
101a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            shift
102a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            ;;
103a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        -s*)
104a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            check_adb_flags
105a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            optarg=`expr -- "$opt" : '-s\(.*\)'`
106a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            ADB_FLAGS=" -s $optarg"
107a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            ;;
108a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        -p)
109a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            check_parameter $1 $2
110a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            OPTION_PROJECT="$2"
111a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            shift
112a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            ;;
113a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        -p*)
114a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            optarg=`expr -- "$opt" : '-p\(.*\)'`
115a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            OPTION_PROJECT="$optarg"
116a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            ;;
117a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        --exec=*)
118a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            OPTION_EXEC="$optarg"
119a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            ;;
120a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        -x)
121a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            check_parameter $1 $2
122a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            OPTION_EXEC="$2"
123a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            shift
124a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            ;;
125a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        -x*)
126a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            optarg=`expr -- "$opt" : '-x\(.*\)'`
127a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            OPTION_EXEC="$optarg"
128a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            ;;
129a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        -e)
130a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            check_adb_flags
131a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            ADB_FLAGS=" -e"
132a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            ;;
133a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        -d)
134a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            check_adb_flags
135a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            ADB_FLAGS=" -d"
136a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            ;;
137a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        --adb=*) # specify ADB command
138a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            OPTION_ADB="$optarg"
139a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            ;;
140a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        --awk=*)
141a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            AWK_CMD="$optarg"
142a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            ;;
143a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        --project=*)
144a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            OPTION_PROJECT="$optarg"
145a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            ;;
146a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        --port=*)
147a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            DEBUG_PORT="$optarg"
148a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            ;;
149a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        --force)
150a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            OPTION_FORCE="yes"
151a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            ;;
1520b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner        --launch-list)
1530b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner            OPTION_LAUNCH_LIST="yes"
1540b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner            ;;
1550b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner        --launch=*)
1560b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner            OPTION_LAUNCH="$optarg"
1570b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner            ;;
1580b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner        --start)
1590b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner            OPTION_START=yes
1600b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner            ;;
161a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        -*) # unknown options
162a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            echo "ERROR: Unknown option '$opt', use --help for list of valid ones."
163a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            exit 1
164a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        ;;
165a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        *)  # Simply record parameter
166a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            if [ -z "$PARAMETERS" ] ; then
167a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner                PARAMETERS="$opt"
168a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            else
169a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner                PARAMETERS="$PARAMETERS $opt"
170a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            fi
171a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            ;;
172a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    esac
173a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    shift
174a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerdone
175a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
176a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ "$OPTION_HELP" = "yes" ] ; then
177a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    echo "Usage: $PROGNAME [options]"
178a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    echo ""
1790b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    echo "Setup a gdb debugging session for your Android NDK application."
1800b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    echo "Read $$NDK/docs/NDK-GDB.TXT for complete usage instructions."
1810b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    echo ""
182a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    echo "Valid options:"
183a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    echo ""
184a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    echo "    --help|-h|-?      Print this help"
185a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    echo "    --verbose         Enable verbose mode"
186a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    echo "    --force           Kill existing debug session if it exists"
1870b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    echo "    --start           Launch application instead of attaching to existing one"
1880b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    echo "    --launch=<name>   Same as --start, but specify activity name (see below)"
1890b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    echo "    --launch-list     List all launchable activity names from manifest"
1900b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    echo "    --project=<path>  Specify application project path"
191a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    echo "    -p <path>         Same as --project=<path>"
1920b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    echo "    --port=<port>     Use tcp:localhost:<port> to communicate with gdbserver [$DEBUG_PORT]"
193a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    echo "    --exec=<file>     Execute gdb initialization commands in <file> after connection"
194a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    echo "    -x <file>         Same as --exec=<file>"
1950b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    echo "    --adb=<file>      Use specific adb command [$ADB_CMD]"
1960b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    echo "    --awk=<file>      Use specific awk command [$AWK_CMD]"
197a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    echo "    -e                Connect to single emulator instance"
198a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    echo "    -d                Connect to single target device"
199a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    echo "    -s <serial>       Connect to specific emulator or device"
200a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    echo ""
201a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    exit 0
202a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi
203a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
204a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerlog "Android NDK installation path: $ANDROID_NDK_ROOT"
205a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
206a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ -n "$OPTION_EXEC" ] ; then
207a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    if [ ! -f "$OPTION_EXEC" ]; then
208a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        echo "ERROR: Invalid initialization file: $OPTION_EXEC"
209a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        exit 1
210a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    fi
211a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi
212a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
213a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Check ADB tool version
214a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ -n "$OPTION_ADB" ] ; then
215a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    ADB_CMD="$OPTION_ADB"
216a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    log "Using specific adb command: $ADB_CMD"
217a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerelse
218a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    if [ -z "$ADB_CMD" ] ; then
219a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        echo "ERROR: The 'adb' tool is not in your path."
220a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        echo "       You can change your PATH variable, or use"
221a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        echo "       --adb=<executable> to point to a valid one."
222a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        exit 1
223a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    fi
224a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    log "Using default adb command: $ADB_CMD"
225a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi
226a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
227a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerADB_VERSION=`$ADB_CMD version`
228a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ $? != 0 ] ; then
229a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    echo "ERROR: Could not run ADB with: $ADB_CMD"
230a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    exit 1
231a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi
232a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerlog "ADB version found: $ADB_VERSION"
233a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
234a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerADB_CMD="${ADB_CMD}${ADB_FLAGS}"
235a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerlog "Using final ADB command: '$ADB_CMD'"
236a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
2374cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turneradb_shell ()
2384cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner{
2394cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner    # Run an adb shell command and return its output.
2404cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner    #
2414cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner    # We need to filter weird control characters like \r that are
2424cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner    # included in the output.
2434cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner    #
2444cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner    $ADB_CMD shell $@ | sed -e 's![[:cntrl:]]!!g'
2454cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner}
246a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
247a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Check the awk tool
2480b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' TurnerAWK_SCRIPTS=$ANDROID_NDK_ROOT/build/awk
2490b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' TurnerAWK_TEST=`$AWK_CMD -f $AWK_SCRIPTS/check-awk.awk`
250a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ $? != 0 ] ; then
2510b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    echo "ERROR: Could not run '$AWK_CMD' command. Do you have it installed properly?"
252a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    exit 1
253a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi
254a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ "$AWK_TEST" != "Pass" ] ; then
255a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    echo "ERROR: Your version of 'awk' is obsolete. Please use --awk=<file> to point to Nawk or Gawk!"
256a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    exit 1
257a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi
258a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
259a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Name of the manifest file
260a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerMANIFEST=AndroidManifest.xml
261a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
262a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Find the root of the application project.
263a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ -n "$OPTION_PROJECT" ] ; then
264a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    PROJECT=$OPTION_PROJECT
265a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    log "Using specified project path: $PROJECT"
266a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    if [ ! -d "$PROJECT" ] ; then
267a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        echo "ERROR: Your --project option does not point to a directory!"
268a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        exit 1
269a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    fi
270a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    if [ ! -f "$PROJECT/$MANIFEST" ] ; then
271a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        echo "ERROR: Your --project does not point to an Android project path!"
272a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        echo "       It is missing a $MANIFEST file."
273a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        exit 1
274a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    fi
275a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerelse
276a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    # Assume we are in the project directory
277a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    if [ -f "$MANIFEST" ] ; then
278a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        PROJECT=.
279a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    else
280a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        PROJECT=
281a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        CURDIR=`pwd`
282a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        while [ "$CURDIR" != "/" ] ; do
283a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            if [ -f "$CURDIR/$MANIFEST" ] ; then
284a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner                PROJECT="$CURDIR"
285a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner                break
286a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            fi
287a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            CURDIR=`dirname $CURDIR`
288a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        done
289a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        if [ -z "$PROJECT" ] ; then
290a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            echo "ERROR: Launch this script from an application project directory, or use --project=<path>."
291a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner            exit 1
292a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        fi
293a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    fi
294a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    log "Using auto-detected project path: $PROJECT"
295a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi
296a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
297a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Extract the package name from the manifest
2980b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' TurnerPACKAGE_NAME=`run_awk_manifest_script extract-package-name.awk`
299a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerlog "Found package name: $PACKAGE_NAME"
300a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ $? != 0 -o "$PACKAGE_NAME" = "<none>" ] ; then
301a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    echo "ERROR: Could not extract package name from $PROJECT/$MANIFEST."
302a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    echo "       Please check that the file is well-formed!"
303a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    exit 1
304a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi
305a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
3060b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner# If --launch-list is used, list all launchable activities, and be done with it
3070b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turnerif [ "$OPTION_LAUNCH_LIST" = "yes" ] ; then
3080b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    log "Extracting list of launchable activities from manifest:"
3090b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    run_awk_manifest_script extract-launchable.awk
3100b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    exit 0
3110b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turnerfi
3120b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner
313a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Check that the application is debuggable, or nothing will work
3140b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' TurnerDEBUGGABLE=`run_awk_manifest_script extract-debuggable.awk`
315a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerlog "Found debuggable flag: $DEBUGGABLE"
316a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ $? != 0 -o "$DEBUGGABLE" != "true" ] ; then
317a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    echo "ERROR: Package $PACKAGE_NAME is not debuggable ! Please fix your manifest,"
318a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    echo "       rebuild your application and re-install it to fix this."
319a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    exit 1
320a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi
321a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
322a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerAPP_ABIS=`get_build_var APP_ABI`
323a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerlog "ABIs targetted by application: $APP_ABIS"
324a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
325a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Check the ADB command, and that we can connect to the device/emulator
326a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerADB_TEST=`$ADB_CMD shell ls`
327a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ $? != 0 ] ; then
328a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    echo "ERROR: Could not connect to device or emulator!"
329a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    echo "       Please check that an emulator is running or a device is connected"
3302e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner    echo "       through USB to this machine. You can use -e, -d and -s <serial>"
331a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    echo "       in case of multiple ones."
332a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    exit 1
333a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi
334a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
3354cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner# Check that the device is running Froyo (API Level 8) or higher
3364cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner#
3374cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' TurnerAPI_LEVEL=`adb_shell getprop ro.build.version.sdk`
3384cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turnerif [ $? != 0 -o -z "$API_LEVEL" ] ; then
3394cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner    echo "ERROR: Could not find target device's supported API level !"
3404cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner    echo "ndk-gdb will only work if your device is running Android 2.2 or higher."
3414cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner    exit 1
3424cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turnerfi
3434cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turnerif [ "$API_LEVEL" -lt "8" ] ; then
3444cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner    echo "ERROR: ndk-gdb requires a target device running Android 2.2 (API level 8) or higher."
3454cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner    echo "The target device is running API level $API_LEVEL !"
3464cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner    exit 1
3474cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turnerfi
3484cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner
349a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Get the target device's supported ABI(s)
350a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# And check that they are supported by the application
351a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner#
352a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerCOMPAT_ABI=none
3534cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' TurnerCPU_ABI=`adb_shell getprop ro.product.cpu.abi`
354a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerecho "$APP_ABIS" | grep -q -F "$CPU_ABI"
355a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ $? = 0 ] ; then
356a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    COMPAT_ABI=$CPU_ABI
357a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi
358a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
3594cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' TurnerCPU_ABI2=`adb_shell getprop ro.product.cpu.abi2`
360a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ -z "$CPU_ABI2" ] ; then
361a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    log "Device CPU ABI: $CPU_ABI"
362a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerelse
363a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    log "Device CPU ABIs: $CPU_ABI $CPU_ABI2"
364a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    echo "$APP_ABIS" | grep -q -F "$CPU_ABI2"
365a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    if [ $? = 0 ] ; then
366a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        COMPAT_ABI=$CPU_ABI2
367a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    fi
368a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi
369a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ "$COMPAT_ABI" = none ] ; then
370a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    echo "ERROR: The device does not support the application's targetted CPU ABIs!"
371a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    if [ "$CPU_ABI2" = "$CPU_ABI" ] ; then
372a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        CPU_ABI2=
373a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    fi
374a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    echo "       Device supports:  $CPU_ABI $CPU_ABI2"
375a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    echo "       Package supports: $APP_ABIS"
376a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    exit 1
377a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi
378a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerlog "Compatible device ABI: $COMPAT_ABI"
379a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
3802e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner# Let's check that the user didn't change the debuggable flag in
3812e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner# the manifest without calling ndk-build afterwards.
3822e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turnerif [ ! -f $PROJECT/libs/$COMPAT_ABI/gdbserver ] ; then
3832e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner    echo "ERROR: Could not find gdbserver binary under $PROJECT/libs/$COMPAT_ABI"
3842e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner    echo "       This usually means you modified your AndroidManifest.xml to set"
3852e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner    echo "       the android:debuggable flag to 'true' but did not rebuild the"
3862e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner    echo "       native binaries. Please call 'ndk-build' to do so,"
3872e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner    echo "       *then* re-install to the device !"
3882e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner    exit 1
3892e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turnerfi
3902e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner
3912e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner# Let's check that 'gdbserver' is properly installed on the device too. If this
3922e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner# is not the case, the user didn't install the proper package after rebuilding.
3932e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner#
3944cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' TurnerDEVICE_GDBSERVER=`adb_shell ls /data/data/$PACKAGE_NAME/lib/gdbserver`
3952e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turnerlog "Found device gdbserver: $DEVICE_GDBSERVER"
3962e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turnerif pattern_match "No such file or directory" "$DEVICE_GDBSERVER" ] ; then
3972e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner    echo "ERROR: Non-debuggable application installed on the target device."
3982e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner    echo "       Please re-install the debuggable version !"
3992e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner    exit 1
4002e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turnerfi
4012e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner
402a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Get information from the build system
403a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerGDBSETUP_INIT=`get_build_var_for_abi NDK_APP_GDBSETUP $COMPAT_ABI`
404a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerlog "Using gdb setup init: $GDBSETUP_INIT"
405a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
406a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerTOOLCHAIN_PREFIX=`get_build_var_for_abi TOOLCHAIN_PREFIX $COMPAT_ABI`
407a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerlog "Using toolchain prefix: $TOOLCHAIN_PREFIX"
408a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
409a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerAPP_OUT=`get_build_var_for_abi TARGET_OUT $COMPAT_ABI`
410a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerlog "Using app out directory: $APP_OUT"
411a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
412a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Find the <dataDir> of the package on the device
4134cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' TurnerDATA_DIR=`adb_shell run-as $PACKAGE_NAME /system/bin/sh -c pwd`
414a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerlog "Found data directory: '$DATA_DIR'"
4154cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turnerif [ $? != 0 -o -z "$DATA_DIR" ] ; then
416a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    echo "ERROR: Could not extract package's data directory. Are you sure that"
4170b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    echo "       your installed application is debuggable?"
418a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    exit 1
419a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi
420a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
4210b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner# Launch the activity if needed
4220b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turnerif [ -n "$OPTION_START" ] ; then
4230b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    # If --launch is used, ignore --start, otherwise extract the first
4240b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    # launchable activity name from the manifest and use it as if --launch=<name>
4250b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    # was used instead.
4260b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    #
4270b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    if [ -z "$OPTION_LAUNCH" ] ; then
4280b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner        OPTION_LAUNCH=`run_awk_manifest_script extract-launchable.awk | sed 2q`
4290b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner        if [ $? != 0 ] ; then
4300b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner            echo "ERROR: Could not extract name of launchable activity from manifest!"
4310b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner            echo "       Try to use --launch=<name> directly instead as a work-around."
4320b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner            exit 1
4330b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner        fi
4340b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner        log "Found first launchable activity: $OPTION_LAUNCH"
4350b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner        if [ -z "$OPTION_LAUNCH" ] ; then
4360b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner            echo "ERROR: It seems that your Application does not have any launchable activity!"
4370b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner            echo "       Please fix your manifest file and rebuild/re-install your application."
4380b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner            exit 1
4390b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner        fi
4400b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    fi
4410b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turnerfi
4420b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner
4430b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turnerif [ -n "$OPTION_LAUNCH" ] ; then
4440b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    log "Launching activity: $PACKAGE_NAME/$OPTION_LAUNCH"
4450b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    run $ADB_CMD shell am start -n $PACKAGE_NAME/$OPTION_LAUNCH
4460b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    if [ $? != 0 ] ; then
4470b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner        echo "ERROR: Could not launch specified activity: $OPTION_LAUNCH"
4480b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner        echo "       Use --launch-list to dump a list of valid values."
4490b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner        exit 1
4500b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    fi
4510b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    # Sleep a bit, it sometimes take one second to start properly
4520b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    # Note that we use the 'sleep' command on the device here.
4530b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    run $ADB_CMD shell sleep 1
4540b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turnerfi
4550b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner
456a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Find the PID of the application being run
4570b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' TurnerPID=`$ADB_CMD shell ps | $AWK_CMD -f $AWK_SCRIPTS/extract-pid.awk -v PACKAGE=$PACKAGE_NAME`
458a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerlog "Found running PID: $PID"
459a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ $? != 0 -o "$PID" = "0" ] ; then
460a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    echo "ERROR: Could not extract PID of application on device/emulator."
4610b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    if [ -n "$OPTION_LAUNCH" ] ; then
4622e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner        echo "       Weird, this probably means one of these:"
4632e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner        echo ""
4642e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner        echo "         - The installed package does not match your current manifest."
4652e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner        echo "         - The application process was terminated."
4662e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner        echo ""
4672e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner        echo "       Try using the --verbose option and look at its output for details."
4680b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    else
4690b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner        echo "       Are you sure the application is already started?"
4700b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner        echo "       Consider using --start or --launch=<name> if not."
4710b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    fi
472a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    exit 1
473a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi
474a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
475a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Check that there is no other instance of gdbserver running
476a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerGDBSERVER_PS=`$ADB_CMD shell ps | grep lib/gdbserver`
477a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ -n "$GDBSERVER_PS" ] ; then
478a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    if [ "$OPTION_FORCE" = "no" ] ; then
479a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        echo "ERROR: Another debug session running, Use --force to kill it."
480a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        exit 1
481a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    fi
482a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    log "Killing existing debugging session"
4830b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    GDBSERVER_PID=`echo $GDBSERVER_PS | $AWK_CMD -f $AWK_SCRIPTS/extract-pid.awk -v PACKAGE=lib/gdbserver`
484a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    if [ $GDBSERVER_PID != 0 ] ; then
485a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner        run $ADB_CMD shell kill -9 $GDBSERVER_PID
486a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    fi
487a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi
488a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
489a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Launch gdbserver now
490a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerDEBUG_SOCKET=debug-socket
491a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerrun $ADB_CMD shell run-as $PACKAGE_NAME lib/gdbserver +$DEBUG_SOCKET --attach $PID &
492a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ $? != 0 ] ; then
4930b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    echo "ERROR: Could not launch gdbserver on the device?"
494a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    exit 1
495a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi
496a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerlog "Launched gdbserver succesfully."
497a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
498a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Setup network redirection
499a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerlog "Setup network redirection"
500a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerrun $ADB_CMD forward tcp:$DEBUG_PORT localfilesystem:$DATA_DIR/$DEBUG_SOCKET
501a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ $? != 0 ] ; then
5020b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    echo "ERROR: Could not setup network redirection to gdbserver?"
5030b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner    echo "       Maybe using --port=<port> to use a different TCP port might help?"
504a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    exit 1
505a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi
506a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
507a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Get the app_server binary from the device
508a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerAPP_PROCESS=$APP_OUT/app_process
509a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerrun adb pull /system/bin/app_process $APP_PROCESS
510a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerlog "Pulled $APP_BINARY from device/emulator."
511a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner
512a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Now launch the appropriate gdb client with the right init commands
513a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner#
514a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerGDBCLIENT=${TOOLCHAIN_PREFIX}gdb
515a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerGDBSETUP=$APP_OUT/gdb.setup
516a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnercp -f $GDBSETUP_INIT $GDBSETUP
517a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerecho "target remote :$DEBUG_PORT" >> $GDBSETUP
518a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ -n "$OPTION_EXEC" ] ; then
519a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner    cat $OPTION_EXEC >> $GDBSETUP
520a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi
521a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner$GDBCLIENT -x $GDBSETUP -e $APP_PROCESS
522