mirror of
https://github.com/status-im/status-mobile.git
synced 2025-01-27 17:06:18 +00:00
Separate logic into shell.nix and derivation.nix to fix nix build
command
Signed-off-by: Pedro Pombeiro <pombeirp@users.noreply.github.com>
This commit is contained in:
parent
7be77fffb0
commit
aeacbd928e
@ -2,7 +2,7 @@ pipeline {
|
|||||||
agent {
|
agent {
|
||||||
docker {
|
docker {
|
||||||
label 'linux'
|
label 'linux'
|
||||||
image 'statusteam/nix:jenkins-1.0.0-150d5721'
|
image 'statusteam/nix:jenkins-1.0.0-e20e5e15'
|
||||||
args (
|
args (
|
||||||
"-v /home/jenkins/tmp:/var/tmp:rw "+
|
"-v /home/jenkins/tmp:/var/tmp:rw "+
|
||||||
"-v /home/jenkins/status-im.keystore:/tmp/status-im.keystore:ro"
|
"-v /home/jenkins/status-im.keystore:/tmp/status-im.keystore:ro"
|
||||||
|
@ -2,7 +2,7 @@ pipeline {
|
|||||||
agent {
|
agent {
|
||||||
docker {
|
docker {
|
||||||
label 'linux'
|
label 'linux'
|
||||||
image 'statusteam/nix:jenkins-1.0.0-150d5721'
|
image 'statusteam/nix:jenkins-1.0.0-e20e5e15'
|
||||||
args (
|
args (
|
||||||
"-v /tmp/Android/Sdk:/home/jenkins/.status/Android/Sdk:rw "+
|
"-v /tmp/Android/Sdk:/home/jenkins/.status/Android/Sdk:rw "+
|
||||||
"-v /var/tmp/lein:/var/tmp/lein:rw "+
|
"-v /var/tmp/lein:/var/tmp/lein:rw "+
|
||||||
|
@ -3,18 +3,18 @@ pipeline {
|
|||||||
/* the -u is necessary for acces to /nix */
|
/* the -u is necessary for acces to /nix */
|
||||||
docker {
|
docker {
|
||||||
label 'linux'
|
label 'linux'
|
||||||
image 'statusteam/nix:jenkins-1.0.0-150d5721'
|
image 'statusteam/nix:jenkins-1.0.0-e20e5e15'
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
environment {
|
environment {
|
||||||
|
CI_ENVIRONMENT = 'jenkins'
|
||||||
/* we source .bash_profile to be able to use nix-store */
|
/* we source .bash_profile to be able to use nix-store */
|
||||||
NIX_SSHOPTS = "-o StrictHostKeyChecking=no source .bash_profile;"
|
NIX_SSHOPTS = "-o StrictHostKeyChecking=no source .bash_profile;"
|
||||||
/* where our /nix/store is hosted */
|
/* where our /nix/store is hosted */
|
||||||
NIX_CACHE_USER = 'nix-cache'
|
NIX_CACHE_USER = 'nix-cache'
|
||||||
NIX_CACHE_HOST = 'master-01.do-ams3.ci.misc.statusim.net'
|
NIX_CACHE_HOST = 'master-01.do-ams3.ci.misc.statusim.net'
|
||||||
/* we add both keys so default binary cache also works */
|
NIX_CONF_DIR = "${env.WORKSPACE}/nix"
|
||||||
NIX_CONF_DIR = "${env.WORKSPACE}/scripts/lib/setup/nix"
|
|
||||||
}
|
}
|
||||||
|
|
||||||
options {
|
options {
|
||||||
@ -37,7 +37,10 @@ pipeline {
|
|||||||
}
|
}
|
||||||
stage('Build') {
|
stage('Build') {
|
||||||
steps {
|
steps {
|
||||||
sh 'nix-shell --run echo'
|
sh """
|
||||||
|
nix build --no-link &&
|
||||||
|
nix-shell --run echo
|
||||||
|
"""
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
stage('Upload') {
|
stage('Upload') {
|
||||||
|
@ -4,13 +4,13 @@ pipeline {
|
|||||||
}
|
}
|
||||||
|
|
||||||
environment {
|
environment {
|
||||||
|
CI_ENVIRONMENT = 'jenkins'
|
||||||
/* we source .bash_profile to be able to use nix-store */
|
/* we source .bash_profile to be able to use nix-store */
|
||||||
NIX_SSHOPTS = "-o StrictHostKeyChecking=no source .bash_profile;"
|
NIX_SSHOPTS = "-o StrictHostKeyChecking=no source .bash_profile;"
|
||||||
/* where our /nix/store is hosted */
|
/* where our /nix/store is hosted */
|
||||||
NIX_CACHE_USER = 'nix-cache'
|
NIX_CACHE_USER = 'nix-cache'
|
||||||
NIX_CACHE_HOST = 'master-01.do-ams3.ci.misc.statusim.net'
|
NIX_CACHE_HOST = 'master-01.do-ams3.ci.misc.statusim.net'
|
||||||
/* we add both keys so default binary cache also works */
|
NIX_CONF_DIR = "${env.WORKSPACE}/nix"
|
||||||
NIX_CONF_DIR = "${env.WORKSPACE}/scripts/lib/setup/nix"
|
|
||||||
}
|
}
|
||||||
|
|
||||||
options {
|
options {
|
||||||
@ -39,6 +39,7 @@ pipeline {
|
|||||||
steps {
|
steps {
|
||||||
sh """
|
sh """
|
||||||
. ~/.nix-profile/etc/profile.d/nix.sh && \
|
. ~/.nix-profile/etc/profile.d/nix.sh && \
|
||||||
|
nix build --no-link && \
|
||||||
nix-shell --run echo
|
nix-shell --run echo
|
||||||
"""
|
"""
|
||||||
}
|
}
|
||||||
|
@ -2,7 +2,7 @@ pipeline {
|
|||||||
agent {
|
agent {
|
||||||
docker {
|
docker {
|
||||||
label 'linux-new'
|
label 'linux-new'
|
||||||
image 'statusteam/nix:jenkins-1.0.0-150d5721'
|
image 'statusteam/nix:jenkins-1.0.0-e20e5e15'
|
||||||
args (
|
args (
|
||||||
"-v /var/tmp/lein:/var/tmp/lein:rw "+
|
"-v /var/tmp/lein:/var/tmp/lein:rw "+
|
||||||
"-v /var/tmp/npm:/var/tmp/npm:rw "
|
"-v /var/tmp/npm:/var/tmp/npm:rw "
|
||||||
|
@ -87,7 +87,8 @@ ARG GIT_COMMIT
|
|||||||
RUN export USER=jenkins \
|
RUN export USER=jenkins \
|
||||||
&& /tmp/nix-install.sh \
|
&& /tmp/nix-install.sh \
|
||||||
&& . ~/.nix-profile/etc/profile.d/nix.sh \
|
&& . ~/.nix-profile/etc/profile.d/nix.sh \
|
||||||
&& nix-build --no-out-link https://github.com/status-im/status-react/tarball/${GIT_COMMIT}
|
&& nix-build --no-out-link https://github.com/status-im/status-react/tarball/${GIT_COMMIT} \
|
||||||
|
&& nix-shell --run 'echo' https://github.com/status-im/status-react/tarball/${GIT_COMMIT}
|
||||||
|
|
||||||
# hack to avoid calling login
|
# hack to avoid calling login
|
||||||
ENV USER=jenkins
|
ENV USER=jenkins
|
||||||
|
@ -20,9 +20,9 @@ def nix_sh(cmd) {
|
|||||||
set +x
|
set +x
|
||||||
. ~/.nix-profile/etc/profile.d/nix.sh
|
. ~/.nix-profile/etc/profile.d/nix.sh
|
||||||
set -x
|
set -x
|
||||||
nix-shell \'${env.WORKSPACE}/default.nix\' \\
|
nix-shell --argstr target-os \'${env.TARGET_PLATFORM}\' \\
|
||||||
--argstr target-os \'${env.TARGET_PLATFORM}\' \\
|
--run \'${cmd}\' \\
|
||||||
--run \'${cmd}\'
|
\'${env.WORKSPACE}/shell.nix\'
|
||||||
"""
|
"""
|
||||||
}
|
}
|
||||||
|
|
||||||
|
112
default.nix
112
default.nix
@ -1,103 +1,19 @@
|
|||||||
# target-os = [ 'windows' 'linux' 'macos' 'android' 'ios' ]
|
# target-os = [ 'windows' 'linux' 'macos' 'android' 'ios' 'all' ]
|
||||||
{ pkgs ? import ((import <nixpkgs> { }).fetchFromGitHub {
|
{ config ? { android_sdk.accept_license = true; },
|
||||||
|
pkgs ? import ((import <nixpkgs> { }).fetchFromGitHub {
|
||||||
owner = "status-im";
|
owner = "status-im";
|
||||||
repo = "nixpkgs";
|
repo = "nixpkgs";
|
||||||
rev = "db492b61572251c2866f6b5e6e94e9d70e7d3021";
|
rev = "db492b61572251c2866f6b5e6e94e9d70e7d3021";
|
||||||
sha256 = "188r7gbcrxi20nj6xh9bmdf3lbjwb94v9s0wpacl7q39g1fca66h";
|
sha256 = "188r7gbcrxi20nj6xh9bmdf3lbjwb94v9s0wpacl7q39g1fca66h";
|
||||||
}) { config = { android_sdk.accept_license = true; }; },
|
}) { inherit config; },
|
||||||
target-os ? "" }:
|
stdenv ? pkgs.stdenv,
|
||||||
|
target-os ? "all" }:
|
||||||
|
|
||||||
with pkgs;
|
(pkgs.callPackage ./derivation.nix { inherit pkgs target-os config; }).overrideAttrs(_: {
|
||||||
let
|
src = null;
|
||||||
targetDesktop = {
|
# TODO: Figure out if there's a better way to do this
|
||||||
"linux" = true;
|
# NOTE: There's a weird difference in behavior between Linux and macOS: in Linux the packages will only be fetched by `nix build` if unpackPhase exists. In macOS it's the other way around :-/
|
||||||
"windows" = true;
|
phases = with stdenv; lib.optional isLinux [ "unpackPhase" ] ++ [ "noPhase" ];
|
||||||
"macos" = true;
|
unpackPhase = "true";
|
||||||
"" = true;
|
noPhase = "mkdir -p $out";
|
||||||
}.${target-os} or false;
|
})
|
||||||
targetMobile = {
|
|
||||||
"android" = true;
|
|
||||||
"ios" = true;
|
|
||||||
"" = true;
|
|
||||||
}.${target-os} or false;
|
|
||||||
# TODO: Try to use stdenv for iOS. The problem is with building iOS as the build is trying to pass parameters to Apple's ld that are meant for GNU's ld (e.g. -dynamiclib)
|
|
||||||
_stdenv = if target-os == "ios" || target-os == "" then stdenvNoCC else stdenv;
|
|
||||||
statusDesktop = callPackage ./nix/desktop { inherit target-os; stdenv = _stdenv; };
|
|
||||||
statusMobile = callPackage ./nix/mobile { inherit target-os status-go; androidPkgs = androidComposition; stdenv = _stdenv; };
|
|
||||||
status-go = callPackage ./nix/status-go { inherit (xcodeenv) composeXcodeWrapper; inherit xcodewrapperArgs; androidPkgs = androidComposition; };
|
|
||||||
nodeInputs = import ./nix/global-node-packages/output {
|
|
||||||
# The remaining dependencies come from Nixpkgs
|
|
||||||
inherit pkgs nodejs;
|
|
||||||
};
|
|
||||||
nodePkgs = [
|
|
||||||
nodejs
|
|
||||||
python27 # for e.g. gyp
|
|
||||||
yarn
|
|
||||||
] ++ (map (x: nodeInputs."${x}") (builtins.attrNames nodeInputs));
|
|
||||||
xcodewrapperArgs = {
|
|
||||||
version = "10.1";
|
|
||||||
};
|
|
||||||
xcodeWrapper = xcodeenv.composeXcodeWrapper xcodewrapperArgs;
|
|
||||||
androidComposition = androidenv.composeAndroidPackages {
|
|
||||||
toolsVersion = "26.1.1";
|
|
||||||
platformToolsVersion = "28.0.2";
|
|
||||||
buildToolsVersions = [ "28.0.3" ];
|
|
||||||
includeEmulator = false;
|
|
||||||
platformVersions = [ "26" "27" ];
|
|
||||||
includeSources = false;
|
|
||||||
includeDocs = false;
|
|
||||||
includeSystemImages = false;
|
|
||||||
systemImageTypes = [ "default" ];
|
|
||||||
abiVersions = [ "armeabi-v7a" ];
|
|
||||||
lldbVersions = [ "2.0.2558144" ];
|
|
||||||
cmakeVersions = [ "3.6.4111459" ];
|
|
||||||
includeNDK = true;
|
|
||||||
ndkVersion = "19.2.5345600";
|
|
||||||
useGoogleAPIs = false;
|
|
||||||
useGoogleTVAddOns = false;
|
|
||||||
includeExtras = [ "extras;android;m2repository" "extras;google;m2repository" ];
|
|
||||||
};
|
|
||||||
|
|
||||||
in _stdenv.mkDerivation rec {
|
|
||||||
name = "env";
|
|
||||||
env = buildEnv { name = name; paths = buildInputs; };
|
|
||||||
buildInputs = with _stdenv; [
|
|
||||||
bash
|
|
||||||
clojure
|
|
||||||
curl
|
|
||||||
git
|
|
||||||
jq
|
|
||||||
leiningen
|
|
||||||
lsof # used in scripts/start-react-native.sh
|
|
||||||
maven
|
|
||||||
ncurses
|
|
||||||
ps # used in scripts/start-react-native.sh
|
|
||||||
watchman
|
|
||||||
unzip
|
|
||||||
wget
|
|
||||||
|
|
||||||
status-go
|
|
||||||
] ++ nodePkgs
|
|
||||||
++ lib.optional isDarwin cocoapods
|
|
||||||
++ lib.optional targetDesktop statusDesktop.buildInputs
|
|
||||||
++ lib.optional targetMobile statusMobile.buildInputs;
|
|
||||||
shellHook =
|
|
||||||
''
|
|
||||||
set -e
|
|
||||||
'' +
|
|
||||||
status-go.shellHook +
|
|
||||||
''
|
|
||||||
export STATUS_GO_INCLUDEDIR=${status-go}/include
|
|
||||||
export STATUS_GO_LIBDIR=${status-go}/lib
|
|
||||||
export STATUS_GO_BINDIR=${status-go.bin}/bin
|
|
||||||
'' +
|
|
||||||
lib.optionalString targetDesktop statusDesktop.shellHook +
|
|
||||||
lib.optionalString targetMobile statusMobile.shellHook +
|
|
||||||
''
|
|
||||||
if [ -n "$ANDROID_SDK_ROOT" ] && [ ! -d "$ANDROID_SDK_ROOT" ]; then
|
|
||||||
./scripts/setup # we assume that if the Android SDK dir does not exist, setup script needs to be run
|
|
||||||
fi
|
|
||||||
set +e
|
|
||||||
'';
|
|
||||||
hardeningDisable = status-go.hardeningDisable;
|
|
||||||
}
|
|
||||||
|
87
derivation.nix
Normal file
87
derivation.nix
Normal file
@ -0,0 +1,87 @@
|
|||||||
|
# target-os = [ 'windows' 'linux' 'macos' 'android' 'ios' ]
|
||||||
|
{ system ? builtins.currentSystem
|
||||||
|
, config ? {}, overlays ? []
|
||||||
|
, pkgs ? (import <nixpkgs> { inherit system config overlays; })
|
||||||
|
, target-os }:
|
||||||
|
|
||||||
|
with pkgs;
|
||||||
|
let
|
||||||
|
sanitized-target-os =
|
||||||
|
if (builtins.any (os: target-os == os) [ "linux" "android" "windows" "macos" "ios" "all" ])
|
||||||
|
then target-os
|
||||||
|
else throw "Unknown value for target-os: '${target-os}'";
|
||||||
|
targetDesktop = {
|
||||||
|
"linux" = true;
|
||||||
|
"windows" = true;
|
||||||
|
"macos" = true;
|
||||||
|
"all" = true;
|
||||||
|
}.${sanitized-target-os} or false;
|
||||||
|
targetMobile = {
|
||||||
|
"android" = true;
|
||||||
|
"ios" = true;
|
||||||
|
"all" = true;
|
||||||
|
}.${sanitized-target-os} or false;
|
||||||
|
# TODO: Try to use stdenv for iOS. The problem is with building iOS as the build is trying to pass parameters to Apple's ld that are meant for GNU's ld (e.g. -dynamiclib)
|
||||||
|
_stdenv = stdenvNoCC;
|
||||||
|
statusDesktop = callPackage ./nix/desktop { inherit target-os; stdenv = _stdenv; };
|
||||||
|
statusMobile = callPackage ./nix/mobile { inherit target-os status-go; androidPkgs = androidComposition; stdenv = _stdenv; };
|
||||||
|
status-go = callPackage ./nix/status-go { inherit (xcodeenv) composeXcodeWrapper; inherit xcodewrapperArgs; androidPkgs = androidComposition; };
|
||||||
|
nodeInputs = import ./nix/global-node-packages/output {
|
||||||
|
# The remaining dependencies come from Nixpkgs
|
||||||
|
inherit pkgs nodejs;
|
||||||
|
};
|
||||||
|
nodePkgs = [
|
||||||
|
nodejs
|
||||||
|
python27 # for e.g. gyp
|
||||||
|
yarn
|
||||||
|
] ++ (map (x: nodeInputs."${x}") (builtins.attrNames nodeInputs));
|
||||||
|
xcodewrapperArgs = {
|
||||||
|
version = "10.1";
|
||||||
|
};
|
||||||
|
xcodeWrapper = xcodeenv.composeXcodeWrapper xcodewrapperArgs;
|
||||||
|
androidComposition = androidenv.composeAndroidPackages {
|
||||||
|
toolsVersion = "26.1.1";
|
||||||
|
platformToolsVersion = "28.0.2";
|
||||||
|
buildToolsVersions = [ "28.0.3" ];
|
||||||
|
includeEmulator = false;
|
||||||
|
platformVersions = [ "26" "27" ];
|
||||||
|
includeSources = false;
|
||||||
|
includeDocs = false;
|
||||||
|
includeSystemImages = false;
|
||||||
|
systemImageTypes = [ "default" ];
|
||||||
|
abiVersions = [ "armeabi-v7a" ];
|
||||||
|
lldbVersions = [ "2.0.2558144" ];
|
||||||
|
cmakeVersions = [ "3.6.4111459" ];
|
||||||
|
includeNDK = true;
|
||||||
|
ndkVersion = "19.2.5345600";
|
||||||
|
useGoogleAPIs = false;
|
||||||
|
useGoogleTVAddOns = false;
|
||||||
|
includeExtras = [ "extras;android;m2repository" "extras;google;m2repository" ];
|
||||||
|
};
|
||||||
|
|
||||||
|
in _stdenv.mkDerivation rec {
|
||||||
|
name = "status-react-build-env";
|
||||||
|
|
||||||
|
buildInputs = with _stdenv; [
|
||||||
|
clojure
|
||||||
|
leiningen
|
||||||
|
maven
|
||||||
|
watchman
|
||||||
|
|
||||||
|
status-go
|
||||||
|
] ++ nodePkgs
|
||||||
|
++ lib.optional isDarwin cocoapods
|
||||||
|
++ lib.optional (!isDarwin) gcc7
|
||||||
|
++ lib.optionals targetDesktop statusDesktop.buildInputs
|
||||||
|
++ lib.optionals targetMobile statusMobile.buildInputs;
|
||||||
|
shellHook =
|
||||||
|
status-go.shellHook +
|
||||||
|
''
|
||||||
|
export STATUS_GO_INCLUDEDIR=${status-go}/include
|
||||||
|
export STATUS_GO_LIBDIR=${status-go}/lib
|
||||||
|
export STATUS_GO_BINDIR=${status-go.bin}/bin
|
||||||
|
'' +
|
||||||
|
lib.optionalString targetDesktop statusDesktop.shellHook +
|
||||||
|
lib.optionalString targetMobile statusMobile.shellHook;
|
||||||
|
hardeningDisable = status-go.hardeningDisable;
|
||||||
|
}
|
@ -6,15 +6,15 @@ with stdenv;
|
|||||||
let
|
let
|
||||||
targetLinux = {
|
targetLinux = {
|
||||||
"linux" = true;
|
"linux" = true;
|
||||||
"" = isLinux;
|
"all" = isLinux;
|
||||||
}.${target-os} or false;
|
}.${target-os} or false;
|
||||||
targetDarwin = {
|
targetDarwin = {
|
||||||
"macos" = true;
|
"macos" = true;
|
||||||
"" = isDarwin;
|
"all" = isDarwin;
|
||||||
}.${target-os} or false;
|
}.${target-os} or false;
|
||||||
targetWindows = {
|
targetWindows = {
|
||||||
"windows" = true;
|
"windows" = true;
|
||||||
"" = isLinux;
|
"all" = isLinux;
|
||||||
}.${target-os} or false;
|
}.${target-os} or false;
|
||||||
linuxPlatform = callPackage ./linux { };
|
linuxPlatform = callPackage ./linux { };
|
||||||
darwinPlatform = callPackage ./macos { };
|
darwinPlatform = callPackage ./macos { };
|
||||||
@ -26,10 +26,10 @@ in
|
|||||||
cmake
|
cmake
|
||||||
extra-cmake-modules
|
extra-cmake-modules
|
||||||
file
|
file
|
||||||
] ++ lib.optional targetLinux linuxPlatform.buildInputs
|
] ++ lib.optionals targetLinux linuxPlatform.buildInputs
|
||||||
++ lib.optional targetDarwin darwinPlatform.buildInputs
|
++ lib.optionals targetDarwin darwinPlatform.buildInputs
|
||||||
++ lib.optional (! targetWindows) qt5.full
|
++ lib.optionals targetWindows windowsPlatform.buildInputs
|
||||||
++ lib.optional targetWindows windowsPlatform.buildInputs;
|
++ lib.optional (! targetWindows) qt5.full;
|
||||||
shellHook = (if target-os == "windows" then ''
|
shellHook = (if target-os == "windows" then ''
|
||||||
unset QT_PATH
|
unset QT_PATH
|
||||||
'' else ''
|
'' else ''
|
||||||
|
@ -8,7 +8,7 @@ let
|
|||||||
|
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
buildInputs = lib.optional isLinux [
|
buildInputs = lib.optionals isLinux [
|
||||||
conan
|
conan
|
||||||
nsis
|
nsis
|
||||||
baseImage
|
baseImage
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
{ stdenv, pkgs, target-os ? "", status-go, androidPkgs }:
|
{ stdenv, pkgs, target-os ? "all", status-go, androidPkgs }:
|
||||||
|
|
||||||
with pkgs;
|
with pkgs;
|
||||||
with stdenv;
|
with stdenv;
|
||||||
@ -7,18 +7,17 @@ let
|
|||||||
gradle = gradle_4_10;
|
gradle = gradle_4_10;
|
||||||
targetAndroid = {
|
targetAndroid = {
|
||||||
"android" = true;
|
"android" = true;
|
||||||
"" = true;
|
"all" = true;
|
||||||
}.${target-os} or false;
|
}.${target-os} or false;
|
||||||
targetIOS = {
|
targetIOS = {
|
||||||
"ios" = true;
|
"ios" = true;
|
||||||
"" = true;
|
"all" = true;
|
||||||
}.${target-os} or false;
|
}.${target-os} or false;
|
||||||
|
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
buildInputs =
|
buildInputs =
|
||||||
[ bundler ruby ] ++ ## bundler/ruby used for fastlane
|
lib.optionals targetAndroid [
|
||||||
lib.optional targetAndroid [
|
|
||||||
openjdk gradle
|
openjdk gradle
|
||||||
];
|
];
|
||||||
shellHook =
|
shellHook =
|
||||||
|
@ -22,8 +22,8 @@ fi
|
|||||||
if command -v "nix" >/dev/null 2>&1; then
|
if command -v "nix" >/dev/null 2>&1; then
|
||||||
echo -e "${GREEN}Configuring Nix shell...${NC}";
|
echo -e "${GREEN}Configuring Nix shell...${NC}";
|
||||||
if [[ $@ == "ENTER_NIX_SHELL" ]]; then
|
if [[ $@ == "ENTER_NIX_SHELL" ]]; then
|
||||||
exec nix-shell
|
exec nix-shell --show-trace
|
||||||
else
|
else
|
||||||
exec nix-shell --run "$@"
|
exec nix-shell --show-trace --run "$@"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
@ -26,7 +26,7 @@ in buildGoPackage rec {
|
|||||||
'';
|
'';
|
||||||
|
|
||||||
patches = [ ./ndk-search-path.patch ./resolve-nix-android-sdk.patch ]
|
patches = [ ./ndk-search-path.patch ./resolve-nix-android-sdk.patch ]
|
||||||
++ lib.optional isDarwin [ ./ignore-nullability-error-on-ios.patch ];
|
++ lib.optional isDarwin ./ignore-nullability-error-on-ios.patch;
|
||||||
|
|
||||||
postPatch = ''
|
postPatch = ''
|
||||||
substituteInPlace cmd/gomobile/install.go --replace "\`adb\`" "\`${platform-tools}/bin/adb\`"
|
substituteInPlace cmd/gomobile/install.go --replace "\`adb\`" "\`${platform-tools}/bin/adb\`"
|
||||||
@ -41,14 +41,14 @@ in buildGoPackage rec {
|
|||||||
mkdir -p $out $bin/lib
|
mkdir -p $out $bin/lib
|
||||||
|
|
||||||
ln -s ${ncurses5}/lib/libncursesw.so.5 $bin/lib/libtinfo.so.5
|
ln -s ${ncurses5}/lib/libncursesw.so.5 $bin/lib/libtinfo.so.5
|
||||||
'' + lib.optionalString isDarwin ''
|
'' + (if isDarwin then ''
|
||||||
wrapProgram $bin/bin/gomobile \
|
wrapProgram $bin/bin/gomobile \
|
||||||
--prefix "PATH" : "${lib.makeBinPath [ xcodeWrapper ]}" \
|
--prefix "PATH" : "${lib.makeBinPath [ xcodeWrapper ]}" \
|
||||||
--prefix "LD_LIBRARY_PATH" : "${lib.makeLibraryPath [ ncurses5 zlib ]}:$bin/lib"
|
--prefix "LD_LIBRARY_PATH" : "${lib.makeLibraryPath [ ncurses5 zlib ]}:$bin/lib"
|
||||||
'' + lib.optionalString (!isDarwin) ''
|
'' else ''
|
||||||
wrapProgram $bin/bin/gomobile \
|
wrapProgram $bin/bin/gomobile \
|
||||||
--prefix "LD_LIBRARY_PATH" : "${lib.makeLibraryPath [ ncurses5 zlib ]}:$bin/lib"
|
--prefix "LD_LIBRARY_PATH" : "${lib.makeLibraryPath [ ncurses5 zlib ]}:$bin/lib"
|
||||||
'' + ''
|
'') + ''
|
||||||
$bin/bin/gomobile init
|
$bin/bin/gomobile init
|
||||||
'';
|
'';
|
||||||
|
|
||||||
|
@ -40,7 +40,7 @@ fi
|
|||||||
|
|
||||||
if [ "$PLATFORM" == 'android' ]; then
|
if [ "$PLATFORM" == 'android' ]; then
|
||||||
if [ ! -d $ANDROID_SDK_ROOT ]; then
|
if [ ! -d $ANDROID_SDK_ROOT ]; then
|
||||||
echo -e "${GREEN}NDK setup not complete, please run 'scripts/setup'!${NC}"
|
echo -e "${GREEN}SDK setup not complete, please run 'scripts/setup'!${NC}"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
if [ ! -d $ANDROID_NDK_ROOT ]; then
|
if [ ! -d $ANDROID_NDK_ROOT ]; then
|
||||||
|
41
shell.nix
Normal file
41
shell.nix
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
{ pkgs ? import <nixpkgs> {},
|
||||||
|
target-os ? "all" }:
|
||||||
|
with pkgs;
|
||||||
|
|
||||||
|
let
|
||||||
|
projectDeps = import ./default.nix { inherit target-os; };
|
||||||
|
targetMobile = {
|
||||||
|
"android" = true;
|
||||||
|
"ios" = true;
|
||||||
|
"all" = true;
|
||||||
|
}.${target-os} or false;
|
||||||
|
# TODO: Try to use stdenv for iOS. The problem is with building iOS as the build is trying to pass parameters to Apple's ld that are meant for GNU's ld (e.g. -dynamiclib)
|
||||||
|
_stdenv = stdenvNoCC;
|
||||||
|
_mkShell = mkShell.override { stdenv = _stdenv; };
|
||||||
|
|
||||||
|
in _mkShell {
|
||||||
|
buildInputs = [
|
||||||
|
# utilities
|
||||||
|
bash
|
||||||
|
curl
|
||||||
|
git
|
||||||
|
jq
|
||||||
|
ncurses
|
||||||
|
lsof # used in scripts/start-react-native.sh
|
||||||
|
ps # used in scripts/start-react-native.sh
|
||||||
|
unzip
|
||||||
|
wget
|
||||||
|
] ++ lib.optionals targetMobile [ bundler ruby ]; # bundler/ruby used for fastlane
|
||||||
|
inputsFrom = [ projectDeps ];
|
||||||
|
shellHook =
|
||||||
|
''
|
||||||
|
set -e
|
||||||
|
'' +
|
||||||
|
projectDeps.shellHook +
|
||||||
|
''
|
||||||
|
if [ -n "$ANDROID_SDK_ROOT" ] && [ ! -d "$ANDROID_SDK_ROOT" ]; then
|
||||||
|
./scripts/setup # we assume that if the Android SDK dir does not exist, setup script needs to be run
|
||||||
|
fi
|
||||||
|
set +e
|
||||||
|
'';
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user