#!/bin/bash
# build script for eclipse adt build on the Linux and Mac platforms
#
# Usage: sdk/eclipse/scripts/build_plugins <build_version>
#
# It expects environment variable ECLIPSE_HOME to be defined to point to _your_
# version of Eclipse RCP (must have the WTP & GEF plugins available too.)
#
# If ECLIPSE_HOME is not provided, this script will _download_ a reference version
# of Eclipse RCP and install it in a specific location.
#
# Other properties, ant scripts that drive the build are defined in ./buildConfig
# Currently, this script will create an update site at ${user.home}/www/no_crawl/android-build
# or at the directory specified using "-d"
# Known Issues:
# - Build does not properly clean up after itself (build server always executes from
# a clean state.)
# - Script will fail if current absolute path has spaces in it.
# - Only linux and OSX are supported for now
# - Do NOT manually invoke this script. Instead use the build_server.sh wrapper
# which does some extra preliminary steps (it builds a few libs needed here.)
set -e # abort this script early if any command fails
#
# -- Utility methods --
#
function printUsage() {
echo "Usage: $0 <build_qualifier> [-i] [-d <destination-directory>] [-a <archivePrefix>] "
echo "<build_qualifier>: build qualifier string"
echo "-i = build internal site. Otherwise, external site will be built"
echo "-d = destination directory. Default is $USER/www/no_crawl/. Cannot contain spaces."
echo "-a = archive prefix. Cannot contain spaces."
}
function die() {
echo $@
exit 1
}
function dieWithUsage() {
echo $@
echo
printUsage
exit 1
}
#
# -- Setup our custom version of Eclipse --
#
# The dependency on the linux platform comes from a series of environment
# variables that the eclipse ant runner expects. These are defined in the
# build.properties file. We can easily support other platforms but would need
# to override those values in this script.
HOST=`uname`
if [ "$HOST" == "Linux" ]; then
BASEOS=linux
BASEWS=gtk
BASEARCH=x86
elif [ "$HOST" == "Darwin" ]; then
BASEOS=macosx
BASEWS=cocoa
BASEARCH=x86
else
die "ERROR: This script is currently only supported on Linux and MacOSX."
fi
# Make sure this runs from the sdk/eclipse plugin.
D=`dirname "$0"`
cd "$D/.."
[ `basename "$PWD"` == "eclipse" ] || dieWithUsage "Please run this script from the sdk/eclipse directory"
# check for number of parameters
[ $# -lt 1 ] && dieWithUsage "ERROR: Not enough parameters"
# check if ECLIPSE_HOME set (ECLIPSE_HOME is were the "eclipse" binary and the
# "plugins" sub-directory are located)
if [ -z "$ECLIPSE_HOME" ]; then
BASE_DIR=/buildbot/eclipse-android
echo "ECLIPSE_HOME not set, using $BASE_DIR as default"
if [ ! -d "$BASE_DIR" ]; then
mkdir -p "$BASE_DIR" || die "Please create a directory $BASE_DIR where Eclipse will be installed, i.e. execute 'mkdir -p $BASE_DIR && chown $USER $BASE_DIR'."
fi
# download the version if not available
VERSION="3.6.2"
BASE_DIR="$BASE_DIR/$VERSION"
scripts/setup_eclipse.sh -p "$BASE_DIR"
ECLIPSE_HOME="$BASE_DIR/eclipse" # path to installed directory
PID_FILE="$BASE_DIR/eclipse.pid"
[ -f "$PID_FILE" ] && ECLIPSE_PID=`cat "$PID_FILE"`
fi
echo "PWD=`pwd`"
echo "ECLIPSE_HOME=$ECLIPSE_HOME"
#
# -- Site parameters and Build version --
#
BUILD_VERSION="$1" ; shift
# parse for build internal site flag. If set, pass in internalSite property to ant scripts
if [ "-i" == "$1" ]; then
shift
echo "Setting for internal site build"
SITE_PARAM="-DinternalSite=1 -DupdateSiteSource=$PWD/sites/internal"
else
SITE_PARAM="-DupdateSiteSource=$PWD/sites/external"
fi
if [ "-d" == $1 ]; then
shift
echo "Setting destination directory to $1"
SITE_PARAM="$SITE_PARAM -DupdateSiteRoot=$1"
shift
fi
if [ "-a" == "$1" ]; then
shift
echo "Setting archivePrefix to $1"
SITE_PARAM="$SITE_PARAM -DarchivePrefix=$1"
shift
fi
#
# -- Configuration directory --
#
# The "configuration directory" will hold the workspace for this build.
# If it contains old data the build may fail so we need to clean it first
# and create it if it doesn't exist.
CONFIG_DIR="../../out/eclipse-configuration-$BUILD_VERSION"
[ -d "$CONFIG_DIR" ] && rm -rfv "$CONFIG_DIR"
mkdir -p "$CONFIG_DIR"
# The "buildConfig" directory contains our customized ant rules
BUILDCONFIG="$PWD/buildConfig"
#
# -- Find Eclipse Launcher --
#
# Get the Eclipse launcher and build script to use
function findFirst() {
for i in "$@"; do
if [ -f "$i" ]; then
echo "$i"
return
fi
done
}
LAUNCHER=`findFirst "$ECLIPSE_HOME"/plugins/org.eclipse.equinox.launcher_*.jar`
BUILDFILE=`findFirst "$ECLIPSE_HOME"/plugins/org.eclipse.pde.build_*/scripts/build.xml`
# make sure we found valid files
if [ ! -f "$LAUNCHER" ]; then
echo "Installation Error: Eclipse plugin org.eclipse.equinox.launcher...jar not detected. " \
"Found '$LAUNCHER'. Aborting."
exit 1
fi
if [ ! -f "$BUILDFILE" ]; then
echo "Installation Error: Eclipse build file org.eclipse.pde.build_.../scripts/build.xml " \
"not detected. Found '$BUILDFILE'. Aborting."
exit 1
fi
#
# Ensure that the src dir exists since it's empty
#
mkdir -p $PWD/plugins/com.android.ide.eclipse.adt.overlay/src
#
# -- Print configuration used and actually execute the build --
#
echo "Eclipse configuration found:"
echo " Eclipse Home: $ECLIPSE_HOME"
echo " Launcher: $LAUNCHER"
echo " Build File: $BUILDFILE"
echo " Build Config: $BUILDCONFIG"
echo " Config Dir: $CONFIG_DIR"
echo " Java: " $(which java)
java -version
# clean input directories to make sure there's nothing left from previous run
rm -fv *.properties *.xml
find . -name "@*" | xargs rm -rfv
# Now execute the ant runner
set +e # don't stop on errors anymore, we want to catch them here
set -x
java \
-jar $LAUNCHER \
-data "$CONFIG_DIR" \
-configuration "$CONFIG_DIR" \
-application org.eclipse.ant.core.antRunner \
-buildfile $BUILDFILE \
-Dbuilder=$BUILDCONFIG \
-DbuildDirectory=$PWD \
-DforceContextQualifier=$BUILD_VERSION \
-DECLIPSE_HOME=$ECLIPSE_HOME \
-Dbaseos=$BASEOS \
-Dbasews=$BASEWS \
-Dbasearch=$BASEARCH \
$SITE_PARAM
RESULT=$?
set +x
if [ "0" != "$RESULT" ]; then
echo "JAVA died with error code $RESULT"
echo "Dump of build config logs:"
for i in "$CONFIG_DIR"/*.log; do
if [ -f "$i" ]; then
echo "----------------------"
echo "--- $i"
echo "----------------------"
cat "$i"
echo
fi
done
fi
#
# -- Cleanup
#
if [ -n "$ECLIPSE_PID" ] && [ -f "$PID_FILE" ]; then
rm -fv "$PID_FILE"
kill -9 "$ECLIPSE_PID"
fi
# Remove build files left by Eclipse all behind
rm -fv *.properties *.xml
find . -name "@*" | xargs rm -rfv
# we're done!