mirror of
https://github.com/ilyakooo0/nixpkgs.git
synced 2024-09-23 13:48:21 +03:00
titaniumenv: add Xcode 10.1 and Titanium 7.5.1 support
This commit is contained in:
parent
9edc2d4dbb
commit
8cec070f8c
@ -1,7 +1,7 @@
|
|||||||
{stdenv, composeAndroidPackages, composeXcodeWrapper, titaniumsdk, titanium, alloy, jdk, python, nodejs, which, file}:
|
{stdenv, composeAndroidPackages, composeXcodeWrapper, titaniumsdk, titanium, alloy, jdk, python, nodejs, which, file}:
|
||||||
{ name, src, preBuild ? "", target, tiVersion ? null
|
{ name, src, preBuild ? "", target, tiVersion ? null
|
||||||
, release ? false, androidKeyStore ? null, androidKeyAlias ? null, androidKeyStorePassword ? null
|
, release ? false, androidKeyStore ? null, androidKeyAlias ? null, androidKeyStorePassword ? null
|
||||||
, iosMobileProvisioningProfile ? null, iosCertificateName ? null, iosCertificate ? null, iosCertificatePassword ? null, iosVersion ? "11.3", iosBuildStore ? false
|
, iosMobileProvisioningProfile ? null, iosCertificateName ? null, iosCertificate ? null, iosCertificatePassword ? null, iosVersion ? "12.1", iosBuildStore ? false
|
||||||
, enableWirelessDistribution ? false, installURL ? null
|
, enableWirelessDistribution ? false, installURL ? null
|
||||||
, xcodeBaseDir ? "/Applications/Xcode.app"
|
, xcodeBaseDir ? "/Applications/Xcode.app"
|
||||||
, androidsdkArgs ? {}
|
, androidsdkArgs ? {}
|
||||||
@ -15,7 +15,7 @@ assert enableWirelessDistribution -> installURL != null;
|
|||||||
|
|
||||||
let
|
let
|
||||||
realAndroidsdkArgs = {
|
realAndroidsdkArgs = {
|
||||||
platformVersions = [ "26" ];
|
platformVersions = [ "28" ];
|
||||||
} // androidsdkArgs;
|
} // androidsdkArgs;
|
||||||
|
|
||||||
androidsdk = (composeAndroidPackages realAndroidsdkArgs).androidsdk;
|
androidsdk = (composeAndroidPackages realAndroidsdkArgs).androidsdk;
|
||||||
@ -46,6 +46,14 @@ stdenv.mkDerivation ({
|
|||||||
buildPhase = ''
|
buildPhase = ''
|
||||||
${preBuild}
|
${preBuild}
|
||||||
|
|
||||||
|
${stdenv.lib.optionalString stdenv.isDarwin ''
|
||||||
|
# Hack that provides a writable alloy package on macOS. Without it the build fails because of a file permission error.
|
||||||
|
alloy=$(dirname $(type -p alloy))/..
|
||||||
|
cp -rv $alloy/* alloy
|
||||||
|
chmod -R u+w alloy
|
||||||
|
export PATH=$(pwd)/alloy/bin:$PATH
|
||||||
|
''}
|
||||||
|
|
||||||
export HOME=${if target == "iphone" then "/Users/$(whoami)" else "$TMPDIR"}
|
export HOME=${if target == "iphone" then "/Users/$(whoami)" else "$TMPDIR"}
|
||||||
|
|
||||||
${stdenv.lib.optionalString (tiVersion != null) ''
|
${stdenv.lib.optionalString (tiVersion != null) ''
|
||||||
|
@ -1,8 +1,17 @@
|
|||||||
{pkgs, pkgs_i686, androidenv, xcodeenv, tiVersion ? "7.1.0.GA"}:
|
{pkgs, pkgs_i686, tiVersion ? "7.1.0.GA"}:
|
||||||
|
|
||||||
rec {
|
rec {
|
||||||
|
androidenv = import ../../nix-androidenvtests/androidenv {
|
||||||
|
inherit pkgs pkgs_i686;
|
||||||
|
};
|
||||||
|
|
||||||
|
xcodeenv = import ../../nix-xcodeenvtests/xcodeenv {
|
||||||
|
inherit (pkgs) stdenv;
|
||||||
|
};
|
||||||
|
|
||||||
titaniumsdk = let
|
titaniumsdk = let
|
||||||
titaniumSdkFile = if tiVersion == "7.1.0.GA" then ./titaniumsdk-7.1.nix
|
titaniumSdkFile = if tiVersion == "7.1.0.GA" then ./titaniumsdk-7.1.nix
|
||||||
|
else if tiVersion == "7.5.1.GA" then ./titaniumsdk-7.5.nix
|
||||||
else throw "Titanium version not supported: "+tiVersion;
|
else throw "Titanium version not supported: "+tiVersion;
|
||||||
in
|
in
|
||||||
import titaniumSdkFile {
|
import titaniumSdkFile {
|
||||||
|
102
pkgs/development/mobile/titaniumenv/titaniumsdk-7.5.nix
Normal file
102
pkgs/development/mobile/titaniumenv/titaniumsdk-7.5.nix
Normal file
@ -0,0 +1,102 @@
|
|||||||
|
{stdenv, fetchurl, unzip, makeWrapper}:
|
||||||
|
|
||||||
|
let
|
||||||
|
# Gradle is a build system that bootstraps itself. This is what it actually
|
||||||
|
# downloads in the bootstrap phase.
|
||||||
|
gradleAllZip = fetchurl {
|
||||||
|
url = http://services.gradle.org/distributions/gradle-4.1-all.zip;
|
||||||
|
sha256 = "1rcrh263vq7a0is800y5z36jj97p67c6zpqzzfcbr7r0qaxb61sw";
|
||||||
|
};
|
||||||
|
|
||||||
|
# A Titanium-Android build requires proguard plugins. We create a fake
|
||||||
|
# repository so that Gradle does not attempt to download them in the builder.
|
||||||
|
# Since there are only 3 plugins required, this is still (sort of) manageable
|
||||||
|
# without a generator.
|
||||||
|
proguardVersion = "5.3.3";
|
||||||
|
|
||||||
|
proguardGradlePOM = fetchurl {
|
||||||
|
url = "https://repo1.maven.org/maven2/net/sf/proguard/proguard-gradle/${proguardVersion}/proguard-gradle-${proguardVersion}.pom";
|
||||||
|
sha256 = "03v9zm3ykfkyb5cs5ald07ph103fh68d5c33rv070r29p71dwszj";
|
||||||
|
};
|
||||||
|
proguardGradleJAR = fetchurl {
|
||||||
|
url = "https://repo1.maven.org/maven2/net/sf/proguard/proguard-gradle/${proguardVersion}/proguard-gradle-${proguardVersion}.jar";
|
||||||
|
sha256 = "0shhpsjfc5gam15jnv1hk718v5c7vi7dwdc3gvmnid6dc85kljzk";
|
||||||
|
};
|
||||||
|
proguardParentPOM = fetchurl {
|
||||||
|
url = "https://repo1.maven.org/maven2/net/sf/proguard/proguard-parent/${proguardVersion}/proguard-parent-${proguardVersion}.pom";
|
||||||
|
sha256 = "0mv0zbwyw8xa4mkc5kw69y5xqashkz9gp123akfvh9f6152l3202";
|
||||||
|
};
|
||||||
|
proguardBasePOM = fetchurl {
|
||||||
|
url = "https://repo1.maven.org/maven2/net/sf/proguard/proguard-base/${proguardVersion}/proguard-base-${proguardVersion}.pom";
|
||||||
|
sha256 = "1jnr6zsxfimb8wglqlwa6rrdc3g3nqf1dyw0k2dq9cj0q4pgn7p5";
|
||||||
|
};
|
||||||
|
proguardBaseJAR = fetchurl {
|
||||||
|
url = "https://repo1.maven.org/maven2/net/sf/proguard/proguard-base/${proguardVersion}/proguard-base-${proguardVersion}.jar";
|
||||||
|
sha256 = "11nwdb9y84cghcx319nsjjf9m035s4s1184zrhzpvaxq2wvqhbhx";
|
||||||
|
};
|
||||||
|
|
||||||
|
# Put the downloaded plugins in a fake Maven repository
|
||||||
|
fakeMavenRepo = stdenv.mkDerivation {
|
||||||
|
name = "fake-maven-repo";
|
||||||
|
buildCommand = ''
|
||||||
|
mkdir -p $out
|
||||||
|
cd $out
|
||||||
|
mkdir -p net/sf/proguard/proguard-gradle/${proguardVersion}
|
||||||
|
cp ${proguardGradlePOM} net/sf/proguard/proguard-gradle/${proguardVersion}/proguard-gradle-${proguardVersion}.pom
|
||||||
|
cp ${proguardGradleJAR} net/sf/proguard/proguard-gradle/${proguardVersion}/proguard-gradle-${proguardVersion}.jar
|
||||||
|
mkdir -p net/sf/proguard/proguard-parent/${proguardVersion}
|
||||||
|
cp ${proguardParentPOM} net/sf/proguard/proguard-parent/${proguardVersion}/proguard-parent-${proguardVersion}.pom
|
||||||
|
mkdir -p net/sf/proguard/proguard-base/${proguardVersion}
|
||||||
|
cp ${proguardBasePOM} net/sf/proguard/proguard-base/${proguardVersion}/proguard-base-${proguardVersion}.pom
|
||||||
|
cp ${proguardBaseJAR} net/sf/proguard/proguard-base/${proguardVersion}/proguard-base-${proguardVersion}.jar
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
in
|
||||||
|
stdenv.mkDerivation {
|
||||||
|
name = "mobilesdk-7.5.1.GA";
|
||||||
|
src = if (stdenv.system == "i686-linux" || stdenv.system == "x86_64-linux") then fetchurl {
|
||||||
|
url = https://builds.appcelerator.com/mobile/7_5_X/mobilesdk-7.5.1.v20190124152315-linux.zip;
|
||||||
|
sha256 = "1ihyh6szl9a2gbdgv13msd3g7i3xi9ifmgsh6v562hqlfi4lixng";
|
||||||
|
}
|
||||||
|
else if stdenv.system == "x86_64-darwin" then fetchurl {
|
||||||
|
url = https://builds.appcelerator.com/mobile/7_5_X/mobilesdk-7.5.1.v20190124152315-osx.zip;
|
||||||
|
sha256 = "1whs1j7fkk2hxr4nxq50d7ic5wj83b1i1jl0p722sqbvkmgxssa2";
|
||||||
|
}
|
||||||
|
else throw "Platform: ${stdenv.system} not supported!";
|
||||||
|
|
||||||
|
buildInputs = [ unzip makeWrapper ];
|
||||||
|
|
||||||
|
buildCommand = ''
|
||||||
|
mkdir -p $out
|
||||||
|
cd $out
|
||||||
|
(yes y | unzip $src) || true
|
||||||
|
|
||||||
|
# Rename ugly version number
|
||||||
|
cd mobilesdk/*
|
||||||
|
mv * 7.5.1.GA
|
||||||
|
cd *
|
||||||
|
|
||||||
|
# Patch bundled gradle build infrastructure to make shebangs work
|
||||||
|
patchShebangs android/templates/gradle
|
||||||
|
|
||||||
|
# Substitute the gradle-all zip URL by a local file to prevent downloads from happening while building an Android app
|
||||||
|
sed -i -e "s|distributionUrl=|#distributionUrl=|" android/templates/gradle/gradle/wrapper/gradle-wrapper.properties
|
||||||
|
cp ${gradleAllZip} android/templates/gradle/gradle/wrapper/gradle-4.1-all.zip
|
||||||
|
echo "distributionUrl=gradle-4.1-all.zip" >> android/templates/gradle/gradle/wrapper/gradle-wrapper.properties
|
||||||
|
|
||||||
|
# Patch maven central repository with our own local directory. This prevents the builder from downloading Maven artifacts
|
||||||
|
sed -i -e 's|mavenCentral()|maven { url "${fakeMavenRepo}" }|' android/templates/build/proguard.gradle
|
||||||
|
|
||||||
|
# Patch some executables
|
||||||
|
|
||||||
|
${if stdenv.system == "i686-linux" then
|
||||||
|
''
|
||||||
|
patchelf --set-interpreter ${stdenv.cc.libc}/lib/ld-linux.so.2 android/titanium_prep.linux32
|
||||||
|
''
|
||||||
|
else if stdenv.system == "x86_64-linux" then
|
||||||
|
''
|
||||||
|
patchelf --set-interpreter ${stdenv.cc.libc}/lib/ld-linux-x86-64.so.2 android/titanium_prep.linux64
|
||||||
|
''
|
||||||
|
else ""}
|
||||||
|
'';
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user