2012-11-08 19:49:36 +04:00
|
|
|
{ stdenv, stdenv_32bit, fetchurl, unzip, makeWrapper
|
2013-07-31 18:00:57 +04:00
|
|
|
, platformTools, buildTools, support, platforms, sysimages, addons
|
2012-11-08 00:10:39 +04:00
|
|
|
, zlib_32bit
|
2013-07-31 18:00:57 +04:00
|
|
|
, libX11_32bit, libxcb_32bit, libXau_32bit, libXdmcp_32bit, libXext_32bit, mesa_32bit
|
|
|
|
, libX11, libXext, libXrender, libxcb, libXau, libXdmcp, mesa
|
2012-11-08 00:10:39 +04:00
|
|
|
, freetype, fontconfig, gtk, atk
|
|
|
|
}:
|
2013-07-31 20:56:27 +04:00
|
|
|
{platformVersions, abiVersions, useGoogleAPIs}:
|
2012-11-08 00:10:39 +04:00
|
|
|
|
|
|
|
stdenv.mkDerivation {
|
2013-07-31 18:00:57 +04:00
|
|
|
name = "android-sdk-22.05";
|
2012-11-08 00:10:39 +04:00
|
|
|
|
|
|
|
src = if (stdenv.system == "i686-linux" || stdenv.system == "x86_64-linux")
|
|
|
|
then fetchurl {
|
2013-07-31 18:00:57 +04:00
|
|
|
url = http://dl.google.com/android/android-sdk_r22.0.5-linux.tgz;
|
|
|
|
md5 = "8201b10c21510f082c54f58a9bb082c8";
|
2012-11-08 00:10:39 +04:00
|
|
|
}
|
|
|
|
else if stdenv.system == "x86_64-darwin" then fetchurl {
|
2013-07-31 18:00:57 +04:00
|
|
|
url = http://dl.google.com/android/android-sdk_r22.0.5-macosx.zip;
|
|
|
|
md5 = "94f3cbe896c332b94ee0408ae610a4b8";
|
2012-11-08 00:10:39 +04:00
|
|
|
}
|
|
|
|
else throw "platform not ${stdenv.system} supported!";
|
|
|
|
|
|
|
|
buildCommand = ''
|
2012-11-08 18:01:06 +04:00
|
|
|
mkdir -p $out/libexec
|
|
|
|
cd $out/libexec
|
2012-11-08 00:10:39 +04:00
|
|
|
unpackFile $src;
|
|
|
|
|
|
|
|
cd android-sdk-*/tools
|
|
|
|
|
|
|
|
${stdenv.lib.optionalString (stdenv.system == "i686-linux" || stdenv.system == "x86_64-linux")
|
|
|
|
''
|
|
|
|
# There are a number of native binaries. We must patch them to let them find the interpreter and libstdc++
|
|
|
|
|
2012-12-20 17:04:52 +04:00
|
|
|
for i in dmtracedump emulator emulator-arm emulator-mips emulator-x86 hprof-conv mksdcard sqlite3
|
2012-11-08 00:10:39 +04:00
|
|
|
do
|
|
|
|
patchelf --set-interpreter ${stdenv_32bit.gcc.libc}/lib/ld-linux.so.2 $i
|
|
|
|
patchelf --set-rpath ${stdenv_32bit.gcc.gcc}/lib $i
|
|
|
|
done
|
|
|
|
|
2012-12-20 17:04:52 +04:00
|
|
|
${stdenv.lib.optionalString (stdenv.system == "x86_64-linux") ''
|
|
|
|
# We must also patch the 64-bit emulator instances, if needed
|
|
|
|
|
|
|
|
for i in emulator64-arm emulator64-mips emulator64-x86
|
|
|
|
do
|
|
|
|
patchelf --set-interpreter ${stdenv.gcc.libc}/lib/ld-linux-x86-64.so.2 $i
|
|
|
|
patchelf --set-rpath ${stdenv.gcc.gcc}/lib64 $i
|
|
|
|
done
|
|
|
|
''}
|
|
|
|
|
2012-11-08 00:10:39 +04:00
|
|
|
# These tools also need zlib in addition to libstdc++
|
|
|
|
|
|
|
|
for i in etc1tool zipalign
|
|
|
|
do
|
|
|
|
patchelf --set-interpreter ${stdenv_32bit.gcc.libc}/lib/ld-linux.so.2 $i
|
|
|
|
patchelf --set-rpath ${stdenv_32bit.gcc.gcc}/lib:${zlib_32bit}/lib $i
|
|
|
|
done
|
|
|
|
|
|
|
|
# The emulators need additional libraries, which are not in the RPATH => let's wrap them
|
|
|
|
|
2012-12-20 17:04:52 +04:00
|
|
|
for i in emulator emulator-arm emulator-mips emulator-x86
|
2012-11-08 00:10:39 +04:00
|
|
|
do
|
|
|
|
wrapProgram `pwd`/$i \
|
2013-08-01 14:43:33 +04:00
|
|
|
--suffix LD_LIBRARY_PATH : `pwd`/lib:${libX11_32bit}/lib:${libxcb_32bit}/lib:${libXau_32bit}/lib:${libXdmcp_32bit}/lib:${libXext_32bit}/lib:${mesa_32bit}/lib
|
2012-11-08 00:10:39 +04:00
|
|
|
done
|
2012-12-20 17:04:52 +04:00
|
|
|
|
|
|
|
${stdenv.lib.optionalString (stdenv.system == "x86_64-linux") ''
|
|
|
|
for i in emulator64-arm emulator64-mips emulator64-x86
|
|
|
|
do
|
|
|
|
wrapProgram `pwd`/$i \
|
2013-08-01 14:43:33 +04:00
|
|
|
--suffix LD_LIBRARY_PATH : `pwd`/lib:${libX11}/lib:${libxcb}/lib:${libXau}/lib:${libXdmcp}/lib:${libXext}/lib:${mesa}/lib
|
2012-12-20 17:04:52 +04:00
|
|
|
done
|
|
|
|
''}
|
2012-11-08 00:10:39 +04:00
|
|
|
''}
|
|
|
|
|
2012-11-08 19:49:36 +04:00
|
|
|
patchShebangs .
|
|
|
|
|
2012-11-08 00:10:39 +04:00
|
|
|
${if stdenv.system == "i686-linux" then
|
|
|
|
''
|
|
|
|
# The monitor requires some more patching
|
|
|
|
|
|
|
|
cd lib/monitor-x86
|
|
|
|
patchelf --set-interpreter ${stdenv.gcc.libc}/lib/ld-linux.so.2 monitor
|
|
|
|
patchelf --set-rpath ${libX11}/lib:${libXext}/lib:${libXrender}/lib:${freetype}/lib:${fontconfig}/lib libcairo-swt.so
|
|
|
|
|
|
|
|
wrapProgram `pwd`/monitor \
|
|
|
|
--prefix LD_LIBRARY_PATH : ${gtk}/lib:${atk}/lib:${stdenv.gcc.gcc}/lib
|
|
|
|
|
|
|
|
cd ../..
|
|
|
|
''
|
|
|
|
else if stdenv.system == "x86_64-linux" then
|
|
|
|
''
|
|
|
|
# The monitor requires some more patching
|
|
|
|
|
|
|
|
cd lib/monitor-x86_64
|
|
|
|
patchelf --set-interpreter ${stdenv.gcc.libc}/lib/ld-linux-x86-64.so.2 monitor
|
|
|
|
patchelf --set-rpath ${libX11}/lib:${libXext}/lib:${libXrender}/lib:${freetype}/lib:${fontconfig}/lib libcairo-swt.so
|
|
|
|
|
|
|
|
wrapProgram `pwd`/monitor \
|
|
|
|
--prefix LD_LIBRARY_PATH : ${gtk}/lib:${atk}/lib:${stdenv.gcc.gcc}/lib
|
|
|
|
|
|
|
|
cd ../..
|
|
|
|
''
|
|
|
|
else ""}
|
|
|
|
|
|
|
|
# Symlink the other sub packages
|
|
|
|
|
|
|
|
cd ..
|
|
|
|
ln -s ${platformTools}/platform-tools
|
2013-07-31 18:00:57 +04:00
|
|
|
ln -s ${buildTools}/build-tools
|
2012-11-08 00:10:39 +04:00
|
|
|
ln -s ${support}/support
|
|
|
|
|
|
|
|
# Symlink required Google API add-ons
|
|
|
|
|
|
|
|
mkdir -p add-ons
|
|
|
|
cd add-ons
|
|
|
|
|
|
|
|
${if useGoogleAPIs then
|
|
|
|
stdenv.lib.concatMapStrings (platformVersion:
|
|
|
|
if (builtins.hasAttr ("google_apis_"+platformVersion) addons) then
|
|
|
|
let
|
|
|
|
googleApis = builtins.getAttr ("google_apis_"+platformVersion) addons;
|
|
|
|
in
|
|
|
|
"ln -s ${googleApis}/* addon-google_apis-${platformVersion}"
|
|
|
|
else "") platformVersions
|
|
|
|
else ""}
|
|
|
|
|
|
|
|
cd ..
|
|
|
|
|
|
|
|
# Symlink required platforms
|
|
|
|
|
|
|
|
mkdir -p platforms
|
|
|
|
cd platforms
|
|
|
|
|
|
|
|
${stdenv.lib.concatMapStrings (platformVersion:
|
|
|
|
if (builtins.hasAttr ("platform_"+platformVersion) platforms) then
|
|
|
|
let
|
|
|
|
platform = builtins.getAttr ("platform_"+platformVersion) platforms;
|
|
|
|
in
|
|
|
|
"ln -s ${platform}/* android-${platformVersion}"
|
|
|
|
else ""
|
|
|
|
) platformVersions}
|
|
|
|
|
|
|
|
cd ..
|
|
|
|
|
|
|
|
# Symlink required system images
|
|
|
|
|
|
|
|
mkdir -p system-images
|
|
|
|
cd system-images
|
|
|
|
|
2013-07-31 20:56:27 +04:00
|
|
|
${stdenv.lib.concatMapStrings (abiVersion:
|
|
|
|
stdenv.lib.concatMapStrings (platformVersion:
|
|
|
|
if (builtins.hasAttr ("sysimg_" + abiVersion + "_" + platformVersion) sysimages) then
|
|
|
|
let
|
|
|
|
sysimg = builtins.getAttr ("sysimg_" + abiVersion + "_" + platformVersion) sysimages;
|
|
|
|
in
|
|
|
|
''
|
|
|
|
mkdir -p android-${platformVersion}
|
|
|
|
cd android-${platformVersion}
|
|
|
|
ln -s ${sysimg}/*
|
|
|
|
cd ..
|
|
|
|
''
|
|
|
|
else ""
|
|
|
|
) platformVersions
|
|
|
|
) abiVersions}
|
2012-11-08 18:01:06 +04:00
|
|
|
|
|
|
|
# Create wrappers to the most important tools and platform tools so that we can run them if the SDK is in our PATH
|
|
|
|
|
|
|
|
ensureDir $out/bin
|
|
|
|
|
|
|
|
for i in $out/libexec/android-sdk-*/tools/*
|
|
|
|
do
|
|
|
|
if [ ! -d $i ] && [ -x $i ]
|
|
|
|
then
|
|
|
|
( echo '#! ${stdenv.shell} -e'
|
|
|
|
echo "cd $out/libexec/android-sdk-*/tools"
|
2012-11-08 19:49:36 +04:00
|
|
|
echo "exec ./$(basename $i) \"\$@\"" ) > $out/bin/$(basename $i)
|
2012-11-08 18:01:06 +04:00
|
|
|
|
|
|
|
chmod +x $out/bin/$(basename $i)
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
for i in $out/libexec/android-sdk-*/platform-tools/*
|
|
|
|
do
|
|
|
|
if [ ! -d $i ] && [ -x $i ]
|
|
|
|
then
|
|
|
|
( echo '#! ${stdenv.shell} -e'
|
|
|
|
echo "cd $out/libexec/android-sdk-*/platform-tools"
|
2012-11-09 14:05:22 +04:00
|
|
|
echo "exec ./$(basename $i) \"\$@\"") > $out/bin/$(basename $i)
|
2012-11-08 18:01:06 +04:00
|
|
|
|
|
|
|
chmod +x $out/bin/$(basename $i)
|
|
|
|
fi
|
|
|
|
done
|
2012-11-08 00:10:39 +04:00
|
|
|
'';
|
|
|
|
|
2012-11-08 19:49:36 +04:00
|
|
|
buildInputs = [ unzip makeWrapper ];
|
2012-11-08 00:10:39 +04:00
|
|
|
}
|