titaniumsdk: add version 3.3 SDK and update kitchensink example
This commit is contained in:
parent
1dc5e5fb8c
commit
a8e4abaf6f
@ -30,6 +30,7 @@ rec {
|
|||||||
titaniumsdk = let
|
titaniumsdk = let
|
||||||
titaniumSdkFile = if tiVersion == "3.1.4.GA" then ./titaniumsdk-3.1.nix
|
titaniumSdkFile = if tiVersion == "3.1.4.GA" then ./titaniumsdk-3.1.nix
|
||||||
else if tiVersion == "3.2.3.GA" then ./titaniumsdk-3.2.nix
|
else if tiVersion == "3.2.3.GA" then ./titaniumsdk-3.2.nix
|
||||||
|
else if tiVersion == "3.3.0.RC2" then ./titaniumsdk-3.3.nix
|
||||||
else throw "Titanium version not supported: "+tiVersion;
|
else throw "Titanium version not supported: "+tiVersion;
|
||||||
in
|
in
|
||||||
import titaniumSdkFile {
|
import titaniumSdkFile {
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
{ titaniumenv, fetchgit, target, androidPlatformVersions ? [ "11" ], tiVersion ? "3.2.1.GA", release ? false
|
{ titaniumenv, fetchgit, target, androidPlatformVersions ? [ "14" ], tiVersion ? "3.2.3.GA", release ? false
|
||||||
, rename ? false, stdenv ? null, newBundleId ? null, iosMobileProvisioningProfile ? null, iosCertificate ? null, iosCertificateName ? null, iosCertificatePassword ? null
|
, rename ? false, stdenv ? null, newBundleId ? null, iosMobileProvisioningProfile ? null, iosCertificate ? null, iosCertificateName ? null, iosCertificatePassword ? null
|
||||||
}:
|
}:
|
||||||
|
|
||||||
@ -7,8 +7,8 @@ assert rename -> (stdenv != null && newBundleId != null && iosMobileProvisioning
|
|||||||
let
|
let
|
||||||
src = fetchgit {
|
src = fetchgit {
|
||||||
url = https://github.com/appcelerator/KitchenSink.git;
|
url = https://github.com/appcelerator/KitchenSink.git;
|
||||||
rev = "0b8175f20f0aa71f93921025dec5d0f3299960ae";
|
rev = "37d766ef9cba6a2d0b22634d3edc1fa8402109a0";
|
||||||
sha256 = "0b2p4wbnlp46wpanqj5h3yfb2hdbh20nxbis8zscj4qlgrnyjdjz";
|
sha256 = "1d4x9zwq92p1krds52bd41qqsnsnb3a7x74bysbiphrvrphz80kk";
|
||||||
};
|
};
|
||||||
|
|
||||||
# Rename the bundle id to something else
|
# Rename the bundle id to something else
|
||||||
|
77
pkgs/development/mobile/titaniumenv/titaniumsdk-3.3.nix
Normal file
77
pkgs/development/mobile/titaniumenv/titaniumsdk-3.3.nix
Normal file
@ -0,0 +1,77 @@
|
|||||||
|
{stdenv, fetchurl, unzip, makeWrapper, python, jdk}:
|
||||||
|
|
||||||
|
stdenv.mkDerivation {
|
||||||
|
name = "mobilesdk-3.3.0.RC2";
|
||||||
|
src = if (stdenv.system == "i686-linux" || stdenv.system == "x86_64-linux") then fetchurl {
|
||||||
|
url = http://builds.appcelerator.com/mobile/3.3.0/mobilesdk-3.3.0.RC2-linux.zip;
|
||||||
|
sha1 = "ad4d0003b81ffc5947c1961548ad4b8591aaec5b";
|
||||||
|
}
|
||||||
|
else if stdenv.system == "x86_64-darwin" then fetchurl {
|
||||||
|
url = http://builds.appcelerator.com/mobile/3.3.0/mobilesdk-3.3.0.RC2-osx.zip;
|
||||||
|
sha1 = "621080fdd48801bfec7113fef1f224caabf0d4dd";
|
||||||
|
}
|
||||||
|
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
|
||||||
|
|
||||||
|
# Rename ugly version number
|
||||||
|
cd mobilesdk/*
|
||||||
|
cd 3.3.0.RC2
|
||||||
|
|
||||||
|
# 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 android
|
||||||
|
|
||||||
|
sed -i -f ${./fixtiverify.sed} builder.py
|
||||||
|
sed -i -f ${./fixtiprofiler.sed} builder.py
|
||||||
|
sed -i -f ${./fixso.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
|
||||||
|
|
||||||
|
mv builder.py .builder.py
|
||||||
|
cat > builder.py <<EOF
|
||||||
|
#!${python}/bin/python
|
||||||
|
|
||||||
|
import os, sys
|
||||||
|
|
||||||
|
os.environ['PYTHONPATH'] = '$(echo ${python.modules.sqlite3}/lib/python*/site-packages)'
|
||||||
|
os.environ['JAVA_HOME'] = '${if stdenv.system == "x86_64-darwin" then jdk else "${jdk}/lib/openjdk"}'
|
||||||
|
|
||||||
|
os.execv('$(pwd)/.builder.py', sys.argv)
|
||||||
|
EOF
|
||||||
|
|
||||||
|
chmod +x builder.py
|
||||||
|
|
||||||
|
'' + stdenv.lib.optionalString (stdenv.system == "x86_64-darwin") ''
|
||||||
|
# 'ditto' utility is needed to copy stuff to the Xcode organizer. Dirty, but this allows it to work.
|
||||||
|
sed -i -e "s|ditto|/usr/bin/ditto|g" $out/mobilesdk/osx/*/iphone/builder.py
|
||||||
|
|
||||||
|
sed -i -e "s|--xcode|--xcode '+process.env['NIX_TITANIUM_WORKAROUND']+'|" $out/mobilesdk/osx/*/iphone/cli/commands/_build.js
|
||||||
|
'';
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user