Added package + build functions for Titanium SDK, a cross-platform mobile development kit
This commit is contained in:
parent
563416500e
commit
c6ff338e27
87
pkgs/development/mobile/titaniumenv/build-app.nix
Normal file
87
pkgs/development/mobile/titaniumenv/build-app.nix
Normal file
@ -0,0 +1,87 @@
|
|||||||
|
{stdenv, androidsdk, titaniumsdk, xcodewrapper}:
|
||||||
|
{ appId, name, src, target, androidPlatformVersions ? [ "8" ]
|
||||||
|
, release ? false, androidKeyStore ? null, androidKeyAlias ? null, androidKeyStorePassword ? null
|
||||||
|
, iosKeyFile ? null, iosCertificateName ? null, iosCertificate ? null, iosCertificatePassword ? null
|
||||||
|
}:
|
||||||
|
|
||||||
|
assert (release && target == "android") -> androidKeyStore != null && androidKeyAlias != null && androidKeyStorePassword != null;
|
||||||
|
assert (release && target == "iphone") -> iosKeyFile != null && iosCertificateName != null && iosCertificate != null && iosCertificatePassword != null;
|
||||||
|
|
||||||
|
let
|
||||||
|
androidsdkComposition = androidsdk {
|
||||||
|
platformVersions = androidPlatformVersions;
|
||||||
|
useGoogleAPIs = true;
|
||||||
|
};
|
||||||
|
in
|
||||||
|
stdenv.mkDerivation {
|
||||||
|
inherit name src;
|
||||||
|
|
||||||
|
buildInputs = [] ++ stdenv.lib.optional (stdenv.system == "x86_64-darwin") xcodewrapper;
|
||||||
|
|
||||||
|
buildPhase = ''
|
||||||
|
export HOME=$TMPDIR
|
||||||
|
|
||||||
|
mkdir -p $out
|
||||||
|
|
||||||
|
${if target == "android" then
|
||||||
|
if release then
|
||||||
|
"${titaniumsdk}/mobilesdk/*/*/android/builder.py distribute ${name} ${androidsdkComposition}/libexec/android-sdk-* $(pwd) ${appId} ${androidKeyStore} ${androidKeyStorePassword} ${androidKeyAlias} $out"
|
||||||
|
else
|
||||||
|
"${titaniumsdk}/mobilesdk/*/*/android/builder.py build ${name} ${androidsdkComposition}/libexec/android-sdk-* $(pwd) ${appId}"
|
||||||
|
|
||||||
|
else if target == "iphone" then
|
||||||
|
if release then
|
||||||
|
''
|
||||||
|
export HOME=/Users/$(whoami)
|
||||||
|
export keychainName=$(basename $out)
|
||||||
|
|
||||||
|
# Create a keychain with the component hash name (should always be unique)
|
||||||
|
security create-keychain -p "" $keychainName
|
||||||
|
security default-keychain -s $keychainName
|
||||||
|
security unlock-keychain -p "" $keychainName
|
||||||
|
security import ${iosCertificate} -k $keychainName -P "${iosCertificatePassword}" -A
|
||||||
|
|
||||||
|
provisioningId=$(grep UUID -A1 -a ${iosKeyFile} | grep -o "[-A-Z0-9]\{36\}")
|
||||||
|
|
||||||
|
# Ensure that the requested provisioning profile can be found
|
||||||
|
|
||||||
|
if [ ! -f "$HOME/Library/MobileDevice/Provisioning Profiles" ]
|
||||||
|
then
|
||||||
|
mkdir -p "$HOME/Library/MobileDevice/Provisioning Profiles"
|
||||||
|
cp ${iosKeyFile} "$HOME/Library/MobileDevice/Provisioning Profiles/$provisioningId.mobileprovision"
|
||||||
|
fi
|
||||||
|
|
||||||
|
${titaniumsdk}/mobilesdk/*/*/iphone/builder.py adhoc 6.0 $(pwd) ${appId} ${name} "$provisioningId" "${iosCertificateName}" universal "$HOME/Library/Keychains/$keychainName"
|
||||||
|
|
||||||
|
# Remove our generated keychain
|
||||||
|
|
||||||
|
security delete-keychain $keychainName
|
||||||
|
''
|
||||||
|
else
|
||||||
|
''
|
||||||
|
# Copy all sources to the output store directory.
|
||||||
|
# Why? Debug application include *.js files, which are symlinked into their
|
||||||
|
# sources. If they are not copied, we have dangling references to the
|
||||||
|
# temp folder.
|
||||||
|
|
||||||
|
cp -av * $out
|
||||||
|
cd $out
|
||||||
|
${titaniumsdk}/mobilesdk/*/*/iphone/builder.py build 6.0 $(pwd) ${appId} ${name}
|
||||||
|
''
|
||||||
|
|
||||||
|
else throw "Target: ${target} is not supported!"}
|
||||||
|
'';
|
||||||
|
|
||||||
|
installPhase = ''
|
||||||
|
mkdir -p $out
|
||||||
|
|
||||||
|
${if target == "android" && release then ""
|
||||||
|
else
|
||||||
|
if target == "android" then
|
||||||
|
''cp $(ls build/android/bin/*.apk | grep -v '\-unsigned.apk') $out''
|
||||||
|
else if target == "iphone" && release then
|
||||||
|
"cp -av build/iphone/build/* $out"
|
||||||
|
else if target == "iphone" then ""
|
||||||
|
else throw "Target: ${target} is not supported!"}
|
||||||
|
'';
|
||||||
|
}
|
18
pkgs/development/mobile/titaniumenv/default.nix
Normal file
18
pkgs/development/mobile/titaniumenv/default.nix
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
{pkgs, pkgs_i686}:
|
||||||
|
|
||||||
|
rec {
|
||||||
|
androidenv = pkgs.androidenv;
|
||||||
|
|
||||||
|
xcodeenv = if pkgs.stdenv.system == "x86_64-darwin" then pkgs.xcodeenv else null;
|
||||||
|
|
||||||
|
titaniumsdk = import ./titaniumsdk.nix {
|
||||||
|
inherit (pkgs) stdenv fetchurl unzip makeWrapper python jdk;
|
||||||
|
};
|
||||||
|
|
||||||
|
buildApp = import ./build-app.nix {
|
||||||
|
inherit (pkgs) stdenv;
|
||||||
|
inherit (androidenv) androidsdk;
|
||||||
|
inherit (xcodeenv) xcodewrapper;
|
||||||
|
inherit titaniumsdk;
|
||||||
|
};
|
||||||
|
}
|
38
pkgs/development/mobile/titaniumenv/examples/default.nix
Normal file
38
pkgs/development/mobile/titaniumenv/examples/default.nix
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
let
|
||||||
|
pkgs = import <nixpkgs> {};
|
||||||
|
pkgs_i686 = import <nixpkgs> { system = "i686-linux"; };
|
||||||
|
in
|
||||||
|
rec {
|
||||||
|
titaniumenv = import ./.. {
|
||||||
|
inherit pkgs pkgs_i686;
|
||||||
|
};
|
||||||
|
|
||||||
|
kitchensink_android = import ./kitchensink {
|
||||||
|
inherit titaniumenv;
|
||||||
|
inherit (pkgs) fetchgit;
|
||||||
|
target = "android";
|
||||||
|
};
|
||||||
|
|
||||||
|
kitchensink_iphone = import ./kitchensink {
|
||||||
|
inherit titaniumenv;
|
||||||
|
inherit (pkgs) fetchgit;
|
||||||
|
target = "iphone";
|
||||||
|
};
|
||||||
|
|
||||||
|
emulate_kitchensink = import ./emulate-kitchensink {
|
||||||
|
inherit (titaniumenv) androidenv;
|
||||||
|
kitchensink = kitchensink_android;
|
||||||
|
};
|
||||||
|
|
||||||
|
simulate_kitchensink_iphone = import ./simulate-kitchensink {
|
||||||
|
inherit (titaniumenv) xcodeenv;
|
||||||
|
kitchensink = kitchensink_iphone;
|
||||||
|
device = "iPhone";
|
||||||
|
};
|
||||||
|
|
||||||
|
simulate_kitchensink_ipad = import ./simulate-kitchensink {
|
||||||
|
inherit (titaniumenv) xcodeenv;
|
||||||
|
kitchensink = kitchensink_iphone;
|
||||||
|
device = "iPad";
|
||||||
|
};
|
||||||
|
}
|
@ -0,0 +1,10 @@
|
|||||||
|
{androidenv, kitchensink}:
|
||||||
|
|
||||||
|
androidenv.emulateApp {
|
||||||
|
name = "kitchensink";
|
||||||
|
app = kitchensink;
|
||||||
|
platformVersion = "8";
|
||||||
|
useGoogleAPIs = true;
|
||||||
|
package = "com.appcelerator.kitchensink";
|
||||||
|
activity = "KitchensinkActivity";
|
||||||
|
}
|
@ -0,0 +1,24 @@
|
|||||||
|
{titaniumenv, fetchgit, target, androidPlatformVersions ? [ "8" ]}:
|
||||||
|
|
||||||
|
titaniumenv.buildApp {
|
||||||
|
name = "KitchenSink";
|
||||||
|
appId = "com.appcelerator.kitchensink";
|
||||||
|
src = fetchgit {
|
||||||
|
url = https://github.com/appcelerator/KitchenSink.git;
|
||||||
|
rev = "0f2c0b818034cc4e6867f0aa2afc98bf77dbff02";
|
||||||
|
sha256 = "de31496cfb5625d7a193bbbc32a8021e4094ffab20ae13ef2e1583b0394d7c60";
|
||||||
|
};
|
||||||
|
|
||||||
|
inherit target androidPlatformVersions;
|
||||||
|
|
||||||
|
/*release = true;
|
||||||
|
androidKeyStore = /home/sander/keystore;
|
||||||
|
androidKeyAlias = "sander";
|
||||||
|
androidKeyStorePassword = "foobar";*/
|
||||||
|
|
||||||
|
/*release = true;
|
||||||
|
iosKeyFile = /Users/sander/Downloads/profile.mobileprovision;
|
||||||
|
iosCertificateName = "My Company";
|
||||||
|
iosCertificate = /Users/sander/Downloads/c.p12;
|
||||||
|
iosCertificatePassword = "";*/
|
||||||
|
}
|
@ -0,0 +1,8 @@
|
|||||||
|
{xcodeenv, kitchensink, device}:
|
||||||
|
|
||||||
|
xcodeenv.simulateApp {
|
||||||
|
name = "kitchensink";
|
||||||
|
app = kitchensink;
|
||||||
|
inherit device;
|
||||||
|
baseDir = "build/iphone/build/Debug-iphonesimulator";
|
||||||
|
}
|
1
pkgs/development/mobile/titaniumenv/fixnativelibs.sed
Normal file
1
pkgs/development/mobile/titaniumenv/fixnativelibs.sed
Normal file
@ -0,0 +1 @@
|
|||||||
|
s|\t\t\t\t\t\t\t\tapk_zip.write(native_lib, path_in_zip)|\t\t\t\t\t\t\t\tinfo = zipfile.ZipInfo(path_in_zip)\n\t\t\t\t\t\t\t\tinfo.compress_type = zipfile.ZIP_DEFLATED\n\t\t\t\t\t\t\t\tinfo.create_system = 3\n\t\t\t\t\t\t\t\tf = open(native_lib)\n\t\t\t\t\t\t\t\tapk_zip.writestr(info, f.read())\n\t\t\t\t\t\t\t\tf.close()|
|
1
pkgs/development/mobile/titaniumenv/fixselfruntimev8.sed
Normal file
1
pkgs/development/mobile/titaniumenv/fixselfruntimev8.sed
Normal file
@ -0,0 +1 @@
|
|||||||
|
s|apk_zip.write(os.path.join(lib_source_dir, fname), lib_dest_dir + fname)|info = zipfile.ZipInfo(lib_dest_dir + fname)\n\t\t\t\t\tinfo.compress_type = zipfile.ZIP_DEFLATED\n\t\t\t\t\tinfo.create_system = 3\n\t\t\t\t\tf = open(os.path.join(lib_source_dir, fname))\n\t\t\t\t\tapk_zip.writestr(info, f.read())\n\t\t\t\t\tf.close()|
|
1
pkgs/development/mobile/titaniumenv/fixtiverify.sed
Normal file
1
pkgs/development/mobile/titaniumenv/fixtiverify.sed
Normal file
@ -0,0 +1 @@
|
|||||||
|
s|apk_zip.write(os.path.join(lib_source_dir, 'libtiverify.so'), lib_dest_dir + 'libtiverify.so')|info = zipfile.ZipInfo(lib_dest_dir + 'libtiverify.so')\n\t\t\tinfo.compress_type = zipfile.ZIP_DEFLATED\n\t\t\tinfo.create_system = 3\n\t\t\tf = open(os.path.join(lib_source_dir, 'libtiverify.so'))\n\t\t\tapk_zip.writestr(info, f.read())\n\t\t\tf.close()|
|
57
pkgs/development/mobile/titaniumenv/titaniumsdk.nix
Normal file
57
pkgs/development/mobile/titaniumenv/titaniumsdk.nix
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
{stdenv, fetchurl, unzip, makeWrapper, python, jdk}:
|
||||||
|
|
||||||
|
stdenv.mkDerivation {
|
||||||
|
name = "titanium-mobilesdk-2.1.5.v20121112144658";
|
||||||
|
src = if (stdenv.system == "i686-linux" || stdenv.system == "x86_64-linux") then fetchurl {
|
||||||
|
url = http://builds.appcelerator.com.s3.amazonaws.com/mobile/2_1_X/mobilesdk-2.1.5.v20121112144658-linux.zip;
|
||||||
|
sha1 = "79f073d11ee893c508c5aa675a3126501dd385fd";
|
||||||
|
}
|
||||||
|
else if stdenv.system == "x86_64-darwin" then fetchurl {
|
||||||
|
url = http://builds.appcelerator.com.s3.amazonaws.com/mobile/2_1_X/mobilesdk-2.1.5.v20121112144658-osx.zip;
|
||||||
|
sha1 = "6a9a726882222d1615de332aa1ca608c15564e1c";
|
||||||
|
}
|
||||||
|
else throw "Platform: ${stdenv.system} not supported!";
|
||||||
|
|
||||||
|
buildInputs = [ unzip makeWrapper ];
|
||||||
|
|
||||||
|
buildCommand = ''
|
||||||
|
mkdir -p $out
|
||||||
|
cd $out
|
||||||
|
yes y | unzip $src
|
||||||
|
|
||||||
|
# Fix shebang header for python scripts
|
||||||
|
|
||||||
|
find . -name \*.py | while read i
|
||||||
|
do
|
||||||
|
sed -i -e "s|#!/usr/bin/env python|#!${python}/bin/python|" $i
|
||||||
|
done
|
||||||
|
|
||||||
|
# Zip files do not support timestamps lower than 1980. We have to apply a few work-arounds to cope with that
|
||||||
|
# Yes, I know it's nasty :-)
|
||||||
|
|
||||||
|
cd mobilesdk/*/*/android
|
||||||
|
|
||||||
|
sed -i -f ${./fixtiverify.sed} builder.py
|
||||||
|
sed -i -f ${./fixselfruntimev8.sed} builder.py
|
||||||
|
sed -i -f ${./fixnativelibs.sed} builder.py
|
||||||
|
|
||||||
|
# Patch some executables
|
||||||
|
|
||||||
|
${if stdenv.system == "i686-linux" then
|
||||||
|
''
|
||||||
|
patchelf --set-interpreter ${stdenv.gcc.libc}/lib/ld-linux.so.2 titanium_prep.linux32
|
||||||
|
''
|
||||||
|
else if stdenv.system == "x86_64-linux" then
|
||||||
|
''
|
||||||
|
patchelf --set-interpreter ${stdenv.gcc.libc}/lib/ld-linux-x86-64.so.2 titanium_prep.linux64
|
||||||
|
''
|
||||||
|
else ""}
|
||||||
|
|
||||||
|
# Wrap builder script
|
||||||
|
|
||||||
|
wrapProgram `pwd`/builder.py \
|
||||||
|
--prefix PYTHONPATH : ${python.modules.sqlite3}/lib/python*/site-packages \
|
||||||
|
--prefix PATH : ${jdk}/bin \
|
||||||
|
--prefix JAVA_HOME : ${jdk}
|
||||||
|
'';
|
||||||
|
}
|
@ -417,6 +417,11 @@ let
|
|||||||
};
|
};
|
||||||
|
|
||||||
xcodeenv = callPackage ../development/mobile/xcodeenv { };
|
xcodeenv = callPackage ../development/mobile/xcodeenv { };
|
||||||
|
|
||||||
|
titaniumenv = import ../development/mobile/titaniumenv {
|
||||||
|
inherit pkgs;
|
||||||
|
pkgs_i686 = pkgsi686Linux;
|
||||||
|
};
|
||||||
|
|
||||||
inherit (androidenv) androidsdk_4_1;
|
inherit (androidenv) androidsdk_4_1;
|
||||||
|
|
||||||
@ -5702,7 +5707,6 @@ let
|
|||||||
# `libblkid' fails to build on GNU/Hurd.
|
# `libblkid' fails to build on GNU/Hurd.
|
||||||
configureFlags = args.configureFlags
|
configureFlags = args.configureFlags
|
||||||
+ " --disable-libblkid --disable-mount --disable-libmount"
|
+ " --disable-libblkid --disable-mount --disable-libmount"
|
||||||
+ " --disable-libmount-mount"
|
|
||||||
+ " --disable-fsck --enable-static --disable-partx";
|
+ " --disable-fsck --enable-static --disable-partx";
|
||||||
doCheck = false;
|
doCheck = false;
|
||||||
CPPFLAGS = # ugly hack for ugly software!
|
CPPFLAGS = # ugly hack for ugly software!
|
||||||
|
Loading…
Reference in New Issue
Block a user