Merge korg/donut into korg/master
Conflicts: tools/eclipse/plugins/README.txt tools/sdkmanager/libs/sdklib/src/com/android/sdklib/avd/AvdManager.java
This commit is contained in:
@@ -19,8 +19,12 @@ set -e # Fail this script as soon as a command fails -- fail early, fail fast
|
||||
# will make some rm/mv commands to fail.
|
||||
FORCE="1"
|
||||
|
||||
PROG_NAME="$0"
|
||||
SDK_ZIP="$1"
|
||||
DIST_DIR="$2"
|
||||
TEMP_DIR="$3"
|
||||
[ -z "$TEMP_DIR" ] && TEMP_DIR=${TMP:-/tmp}
|
||||
|
||||
|
||||
function die() {
|
||||
echo "Error:" $*
|
||||
@@ -28,9 +32,23 @@ function die() {
|
||||
exit 1
|
||||
}
|
||||
|
||||
function usage() {
|
||||
echo "Usage: ${PROG_NAME} linux_or_mac_sdk.zip output_dir [temp_dir]"
|
||||
echo "If temp_dir is not given, \$TMP is used. If that's missing, /tmp is used."
|
||||
status
|
||||
exit 2
|
||||
}
|
||||
|
||||
function status() {
|
||||
echo "Current values:"
|
||||
echo "- Input SDK: ${SDK_ZIP:-missing}"
|
||||
echo "- Output dir: ${DIST_DIR:-missing}"
|
||||
echo "- Temp dir: ${TEMP_DIR:-missing}"
|
||||
}
|
||||
|
||||
function check() {
|
||||
[ -f "$SDK_ZIP" ] || die "Pass the path of an existing Linux/Darwin SDK .zip as first parameter"
|
||||
[ -d "$DIST_DIR" ] || die "Pass the output directory as second parameter"
|
||||
[ -f "$SDK_ZIP" ] || usage
|
||||
[ -d "$DIST_DIR" ] || usage
|
||||
|
||||
# Use the BUILD_ID as SDK_NUMBER if defined, otherwise try to get it from the
|
||||
# provided zip filename.
|
||||
@@ -82,21 +100,22 @@ function package() {
|
||||
echo
|
||||
echo "Packaging..."
|
||||
DEST_NAME="android-sdk_${SDK_NUMBER}_windows"
|
||||
DEST="$DIST_DIR/$DEST_NAME"
|
||||
DEST_NAME_ZIP="${DEST_NAME}.zip"
|
||||
|
||||
TEMP_SDK_DIR="$TEMP_DIR/$DEST_NAME"
|
||||
|
||||
# Unzip current linux/mac SDK and rename using the windows name
|
||||
if [[ -n "$FORCE" || ! -d "$DEST" ]]; then
|
||||
[ -e "$DEST" ] && rm -rfv "$DEST" # cleanup dest first if exists
|
||||
if [[ -n "$FORCE" || ! -d "$TEMP_SDK_DIR" ]]; then
|
||||
[ -e "$TEMP_SDK_DIR" ] && rm -rfv "$TEMP_SDK_DIR" # cleanup dest first if exists
|
||||
UNZIPPED=`basename "$SDK_ZIP"`
|
||||
UNZIPPED="$DIST_DIR/${UNZIPPED/.zip/}"
|
||||
UNZIPPED="$TEMP_DIR/${UNZIPPED/.zip/}"
|
||||
[ -e "$UNZIPPED" ] && rm -rfv "$UNZIPPED" # cleanup unzip dir (if exists)
|
||||
unzip "$SDK_ZIP" -d "$DIST_DIR"
|
||||
mv -v "$UNZIPPED" "$DEST"
|
||||
unzip "$SDK_ZIP" -d "$TEMP_DIR"
|
||||
mv -v "$UNZIPPED" "$TEMP_SDK_DIR"
|
||||
fi
|
||||
|
||||
# Assert that the package contains only one platform
|
||||
PLATFORMS="$DEST/platforms"
|
||||
PLATFORMS="$TEMP_SDK_DIR/platforms"
|
||||
THE_PLATFORM=`echo $PLATFORMS/*`
|
||||
PLATFORM_TOOLS=$THE_PLATFORM/tools
|
||||
echo "Platform found: " $THE_PLATFORM
|
||||
@@ -107,53 +126,86 @@ function package() {
|
||||
|
||||
|
||||
# USB Driver for ADB
|
||||
mkdir -pv $DEST/usb_driver/x86
|
||||
cp -rv development/host/windows/prebuilt/usb/driver/* $DEST/usb_driver/x86/
|
||||
mkdir -pv $DEST/usb_driver/amd64
|
||||
cp -rv development/host/windows/prebuilt/usb/driver_amd_64/* $DEST/usb_driver/amd64/
|
||||
mkdir -pv $TEMP_SDK_DIR/usb_driver/x86
|
||||
cp -rv development/host/windows/prebuilt/usb/driver/* $TEMP_SDK_DIR/usb_driver/x86/
|
||||
mkdir -pv $TEMP_SDK_DIR/usb_driver/x86_64
|
||||
cp -rv development/host/windows/prebuilt/usb/driver_amd_64/* $TEMP_SDK_DIR/usb_driver/x86_64/
|
||||
|
||||
# Remove obsolete stuff from tools & platform
|
||||
TOOLS="$DEST/tools"
|
||||
LIB="$DEST/tools/lib"
|
||||
rm -v "$TOOLS"/{adb,emulator,traceview,draw9patch,hierarchyviewer,apkbuilder,ddms,dmtracedump,hprof-conv,mksdcard,sqlite3,android}
|
||||
rm -v --force "$LIB"/*.so "$LIB"/*.jnilib
|
||||
TOOLS="$TEMP_SDK_DIR/tools"
|
||||
LIB="$TEMP_SDK_DIR/tools/lib"
|
||||
rm -v "$TOOLS"/{adb,android,apkbuilder,ddms,dmtracedump,draw9patch,emulator}
|
||||
rm -v "$TOOLS"/{hierarchyviewer,hprof-conv,mksdcard,sqlite3,traceview}
|
||||
rm -v "$LIB"/*/swt.jar
|
||||
rm -v "$PLATFORM_TOOLS"/{aapt,aidl,dx,dexdump}
|
||||
|
||||
|
||||
# Copy all the new stuff in tools
|
||||
# Note: some tools are first copied here and then moved in platforms/<name>/tools/
|
||||
cp -v out/host/windows-x86/bin/*.{exe,dll} "$TOOLS"
|
||||
cp -v prebuilt/windows/swt/*.{jar,dll} "$LIB"
|
||||
cp -v out/host/windows-x86/bin/*.{exe,dll} "$TOOLS"/
|
||||
mkdir -pv "$LIB"/x86
|
||||
cp -v prebuilt/windows/swt/swt.jar "$LIB"/x86/
|
||||
mkdir -pv "$LIB"/x86_64
|
||||
cp -v prebuilt/windows-x86_64/swt/swt.jar "$LIB"/x86_64/
|
||||
|
||||
# If you want the emulator NOTICE in the tools dir, uncomment the following line:
|
||||
# cp -v external/qemu/NOTICE "$TOOLS"/emulator_NOTICE.txt
|
||||
|
||||
# We currently need libz from MinGW for aapt
|
||||
cp -v /cygdrive/c/cygwin/bin/mgwz.dll "$TOOLS"
|
||||
cp -v /cygdrive/c/cygwin/bin/mgwz.dll "$TOOLS"/
|
||||
|
||||
# Update a bunch of bat files
|
||||
cp -v development/tools/apkbuilder/etc/apkbuilder.bat "$TOOLS"
|
||||
cp -v development/tools/ddms/app/etc/ddms.bat "$TOOLS"
|
||||
cp -v development/tools/traceview/etc/traceview.bat "$TOOLS"
|
||||
cp -v development/tools/hierarchyviewer/etc/hierarchyviewer.bat "$TOOLS"
|
||||
cp -v development/tools/draw9patch/etc/draw9patch.bat "$TOOLS"
|
||||
cp -v development/tools/sdkmanager/app/etc/android.bat "$TOOLS"
|
||||
cp -v development/tools/apkbuilder/etc/apkbuilder.bat "$TOOLS"/
|
||||
cp -v development/tools/ddms/app/etc/ddms.bat "$TOOLS"/
|
||||
cp -v development/tools/traceview/etc/traceview.bat "$TOOLS"/
|
||||
cp -v development/tools/hierarchyviewer/etc/hierarchyviewer.bat "$TOOLS"/
|
||||
cp -v development/tools/draw9patch/etc/draw9patch.bat "$TOOLS"/
|
||||
cp -v development/tools/sdkmanager/app/etc/android.bat "$TOOLS"/
|
||||
|
||||
# Put the JetCreator tools, content and docs (not available in the linux SDK)
|
||||
JET="$TOOLS/Jet"
|
||||
JETCREATOR="$JET/JetCreator"
|
||||
JETDEMOCONTENT="$JET/demo_content"
|
||||
JETLOGICTEMPLATES="$JET/logic_templates"
|
||||
JETDOC="$TEMP_SDK_DIR/docs/JetCreator"
|
||||
|
||||
# need to rm these folders since a Mac SDK will have them and it might create a conflict
|
||||
rm -rfv "$JET"
|
||||
rm -rfv "$JETDOC"
|
||||
|
||||
# now create fresh folders for JetCreator
|
||||
mkdir -v "$JET"
|
||||
mkdir -v "$JETDOC"
|
||||
|
||||
cp -rv external/sonivox/jet_tools/JetCreator "$JETCREATOR"/
|
||||
cp -rv external/sonivox/jet_tools/JetCreator_content "$JETDEMOCONTENT"/
|
||||
cp -rv external/sonivox/jet_tools/logic_templates "$JETLOGICTEMPLATES"/
|
||||
chmod -vR u+w "$JETCREATOR" # fixes an issue where Cygwin might copy the above as u+rx only
|
||||
cp -v prebuilt/windows/jetcreator/EASDLL.dll "$JETCREATOR"/
|
||||
|
||||
cp -v external/sonivox/docs/JET_Authoring_Guidelines.html "$JETDOC"/
|
||||
cp -rv external/sonivox/docs/JET_Authoring_Guidelines_files "$JETDOC"/
|
||||
cp -v external/sonivox/docs/JET_Creator_User_Manual.html "$JETDOC"/
|
||||
cp -rv external/sonivox/docs/JET_Creator_User_Manual_files "$JETDOC"/
|
||||
|
||||
# Copy or move platform specific tools to the default platform.
|
||||
cp -v dalvik/dx/etc/dx.bat "$PLATFORM_TOOLS"
|
||||
cp -v dalvik/dx/etc/dx.bat "$PLATFORM_TOOLS"/
|
||||
# Note: mgwz.dll must be in same folder than aapt.exe
|
||||
mv -v "$TOOLS"/{aapt.exe,aidl.exe,dexdump.exe,mgwz.dll} "$PLATFORM_TOOLS"
|
||||
mv -v "$TOOLS"/{aapt.exe,aidl.exe,dexdump.exe,mgwz.dll} "$PLATFORM_TOOLS"/
|
||||
|
||||
# Fix EOL chars to make window users happy - fix all files at the top level only
|
||||
# as well as all batch files including those in platforms/<name>/tools/
|
||||
find "$DIST_DIR" -maxdepth 1 -type f -writable -print0 | xargs -0 unix2dos -D
|
||||
find "$DIST_DIR" -maxdepth 3 -name "*.bat" -type f -writable -print0 | xargs -0 unix2dos -D
|
||||
find "$TEMP_SDK_DIR" -maxdepth 1 -type f -writable -print0 | xargs -0 unix2dos -D
|
||||
find "$TEMP_SDK_DIR" -maxdepth 3 -name "*.bat" -type f -writable -print0 | xargs -0 unix2dos -D
|
||||
|
||||
# Done.. Zip it
|
||||
pushd "$DIST_DIR" > /dev/null
|
||||
# Done.. Zip it. Clean the temp folder ONLY if the zip worked (to ease debugging)
|
||||
pushd "$TEMP_DIR" > /dev/null
|
||||
[ -e "$DEST_NAME_ZIP" ] && rm -rfv "$DEST_NAME_ZIP"
|
||||
zip -9r "$DEST_NAME_ZIP" "$DEST_NAME" && rm -rfv "$DEST_NAME"
|
||||
popd > /dev/null
|
||||
|
||||
# Now move the final zip from the temp dest to the final dist dir
|
||||
mv -v "$TEMP_DIR/$DEST_NAME_ZIP" "$DIST_DIR/$DEST_NAME_ZIP"
|
||||
|
||||
echo "Done"
|
||||
echo
|
||||
echo "Resulting SDK is in $DIST_DIR/$DEST_NAME_ZIP"
|
||||
@@ -165,6 +217,7 @@ function package() {
|
||||
}
|
||||
|
||||
check
|
||||
status
|
||||
build
|
||||
package
|
||||
|
||||
|
||||
Reference in New Issue
Block a user