| #!/bin/sh |
| # |
| # Copyright (C) 2010 The Android Open Source Project |
| # |
| # Licensed under the Apache License, Version 2.0 (the "License"); |
| # you may not use this file except in compliance with the License. |
| # You may obtain a copy of the License at |
| # |
| # http://www.apache.org/licenses/LICENSE-2.0 |
| # |
| # Unless required by applicable law or agreed to in writing, software |
| # distributed under the License is distributed on an "AS IS" BASIS, |
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| # See the License for the specific language governing permissions and |
| # limitations under the License. |
| # |
| # This shell script is a wrapper to launch the NDK build from the |
| # command-line inside an application project path. |
| # |
| # Typical usage is: |
| # |
| # cd $PROJECT_PATH |
| # ndk-build |
| # |
| # Assuming that the Android NDK root path is in your PATH. However, |
| # you can also invoke it directly as: |
| # |
| # $NDK_ROOT/ndk-build |
| # |
| # This really is a tiny wrapper around GNU Make. |
| # |
| |
| # Ensure we get the full path of this script's directory |
| # this is needed if the caller uses the -C <path> GNU Make |
| # option, as in: |
| # |
| # cd ndk |
| # ./ndk-build -C <project-path> |
| # |
| PROGDIR=`dirname $0` |
| PROGDIR=`cd $PROGDIR && pwd` |
| |
| # Check if absolute NDK path contain space |
| # |
| case $PROGDIR in |
| *\ *) echo "ERROR: NDK path cannot contain space" |
| exit 1 |
| ;; |
| esac |
| |
| # If NDK_LOG is set to 1 or true in the environment, or the command-line |
| # then enable log messages below |
| if [ -z "$NDK_LOG" ]; then |
| NDK_LOG=0 |
| fi |
| |
| for opt; do |
| case $opt in |
| NDK_LOG=1|NDK_LOG=true) |
| NDK_LOG=1 |
| ;; |
| NDK_LOG=*) |
| NDK_LOG=0 |
| ;; |
| esac |
| done |
| |
| if [ "$NDK_LOG" = "true" ]; then |
| NDK_LOG=1 |
| fi |
| if [ "$NDK_LOG" = 1 ]; then |
| log () { |
| echo "$@" |
| } |
| else |
| log () { |
| : # nothing |
| } |
| fi |
| |
| # Detect host operating system and architecture |
| # The 64-bit / 32-bit distinction gets tricky on Linux and Darwin because |
| # uname -m returns the kernel's bit size, and it's possible to run with |
| # a 64-bit kernel and a 32-bit userland. |
| # |
| HOST_OS=$(uname -s) |
| case $HOST_OS in |
| Darwin) HOST_OS=darwin;; |
| Linux) HOST_OS=linux;; |
| FreeBsd) HOST_OS=freebsd;; |
| CYGWIN*|*_NT-*) HOST_OS=cygwin;; |
| *) echo "ERROR: Unknown host operating system: $HOST_OS" |
| exit 1 |
| esac |
| log "HOST_OS=$HOST_OS" |
| |
| HOST_ARCH=$(uname -m) |
| case $HOST_ARCH in |
| i?86) HOST_ARCH=x86;; |
| x86_64|amd64) HOST_ARCH=x86_64;; |
| *) echo "ERROR: Unknown host CPU architecture: $HOST_ARCH" |
| exit 1 |
| esac |
| log "HOST_ARCH=$HOST_ARCH" |
| |
| # Detect 32-bit userland on 64-bit kernels |
| HOST_TAG="$HOST_OS-$HOST_ARCH" |
| case $HOST_TAG in |
| linux-x86_64|darwin-x86_64) |
| # we look for x86_64 or x86-64 in the output of 'file' for our shell |
| # the -L flag is used to dereference symlinks, just in case. |
| file -L "$SHELL" | grep -q "x86[_-]64" |
| if [ $? != 0 ]; then |
| HOST_ARCH=x86 |
| HOST_TAG=$HOST_OS-x86 |
| log "HOST_ARCH=$HOST_ARCH (32-bit userland detected)" |
| fi |
| ;; |
| windows-x86) # Special case windows-x86 -> windows |
| HOST_TAG=windows |
| esac |
| |
| # Check that we have 64-bit binaries on 64-bit system, otherwise fallback |
| # on 32-bit ones. This gives us more freedom in packaging the NDK. |
| if [ $HOST_ARCH = x86_64 -a ! -d $PROGDIR/prebuilt/$HOST_TAG ]; then |
| HOST_TAG=$HOST_OS-x86 |
| if [ $HOST_TAG = windows-x86 ]; then |
| HOST_TAG=windows |
| fi |
| log "HOST_TAG=$HOST_TAG (no 64-bit prebuilt binaries detected)" |
| else |
| log "HOST_TAG=$HOST_TAG" |
| fi |
| |
| # If GNUMAKE is defined, check that it points to a valid file |
| if [ -n "$GNUMAKE" ] ; then |
| ABS_GNUMAKE=`which $GNUMAKE 2> /dev/null` |
| if [ $? != 0 ] ; then |
| echo "ERROR: Your GNUMAKE variable is defined to an invalid name: $GNUMAKE" |
| echo "Please fix it to point to a valid make executable (e.g. /usr/bin/make)" |
| exit 1 |
| fi |
| GNUMAKE="$ABS_GNUMAKE" |
| log "GNUMAKE=$GNUMAKE (from environment variable)" |
| else |
| # Otherwise use the prebuilt version for our host tag, if it exists |
| # Note: we intentionally do not provide prebuilt make binaries for Cygwin |
| # or MSys. |
| GNUMAKE=$PROGDIR/prebuilt/$HOST_TAG/bin/make |
| if [ ! -f "$GNUMAKE" ]; then |
| # Otherwise, use 'make' and check that it is available |
| GNUMAKE=`which make 2> /dev/null` |
| if [ $? != 0 ] ; then |
| echo "ERROR: Cannot find 'make' program. Please install Cygwin make package" |
| echo "or define the GNUMAKE variable to point to it." |
| exit 1 |
| fi |
| log "GNUMAKE=$GNUMAKE (system path)" |
| else |
| log "GNUMAKE=$GNUMAKE (NDK prebuilt)" |
| fi |
| fi |
| |
| # On Windows, when running under cygwin, check that we are |
| # invoking a cygwin-compatible GNU Make binary. It is unfortunately |
| # common for app developers to have another non cygwin-compatible |
| # 'make' program in their PATH. |
| # |
| if [ "$OSTYPE" = "cygwin" ] ; then |
| GNUMAKE=`cygpath -u $GNUMAKE` |
| PROGDIR_MIXED=`cygpath -m $PROGDIR` |
| CYGWIN_GNUMAKE=`$GNUMAKE -f "$PROGDIR_MIXED/build/core/check-cygwin-make.mk" 2>&1` |
| if [ $? != 0 ] ; then |
| echo "ERROR: You are using a non-Cygwin compatible Make program." |
| echo "Currently using: `cygpath -m $GNUMAKE`" |
| echo "" |
| echo "To solve the issue, follow these steps:" |
| echo "" |
| echo "1. Ensure that the Cygwin 'make' package is installed." |
| echo " NOTE: You will need GNU Make 3.81 or later!" |
| echo "" |
| echo "2. Define the GNUMAKE environment variable to point to it, as in:" |
| echo "" |
| echo " export GNUMAKE=/usr/bin/make" |
| echo "" |
| echo "3. Call 'ndk-build' again." |
| echo "" |
| exit 1 |
| fi |
| log "Cygwin-compatible GNU make detected" |
| fi |
| |
| $GNUMAKE -f $PROGDIR/build/core/build-local.mk "$@" |