mirror of
https://github.com/status-im/status-mobile.git
synced 2025-01-10 16:56:31 +00:00
Jakub Sokołowski
58d20967ae
For some unknown to me reason we are using a different Yarn call to Shadow-cljs to generate the JSBundle for iOS builds, while the one created by the Android derivation shoudl be exactly the same. I'm changing the target to just be `make jsbundle` while keeping aliases referencing old naming, and moving things around in `nix` folder to reflect the fact that the derivation is no longer Android-specific. Also, crucially, I've changed the `import` in `index.js` to use the `./result/index.js` path, since that's what Nix creates. I'm not sure if this clashes with any developer workflow that takes place locally, so I'd appreciate some testing from developers. Depends on: https://github.com/status-im/status-jenkins-lib/pull/67 Signed-off-by: Jakub Sokołowski <jakub@status.im>
83 lines
2.6 KiB
Nix
83 lines
2.6 KiB
Nix
#
|
|
# This Nix expression builds the js files for the current repository given a node modules Nix expression
|
|
#
|
|
|
|
{ stdenv, lib, deps, pkgs }:
|
|
|
|
# Path to the file containing secret environment variables
|
|
{ secretsFile ? "" }:
|
|
|
|
stdenv.mkDerivation {
|
|
name = "status-mobile-jsbundle";
|
|
src =
|
|
let path = ./../../..;
|
|
# We use builtins.path so that we can name the resulting derivation,
|
|
# otherwise the name would be taken from the checkout directory,
|
|
# which is outside of our control inherit path;
|
|
in builtins.path {
|
|
inherit path;
|
|
name = "status-mobile-source-jsbundle";
|
|
filter =
|
|
# Keep this filter as restrictive as possible in order to avoid
|
|
# unnecessary rebuilds and limit closure size
|
|
lib.mkFilter {
|
|
root = path;
|
|
ignoreVCS = false;
|
|
include = [
|
|
"VERSION" "BUILD_NUMBER" "scripts/version/.*"
|
|
"src/.*" "shadow-cljs.edn"
|
|
# I want to avoid including the whole .git directory
|
|
".git/HEAD" ".git/objects" ".git/refs/heads/.*"
|
|
# shadow-cljs expects these for deps resolution
|
|
"package.json" "yarn.lock"
|
|
# build stat's images to check if they exist
|
|
"resources/.*" "translations/.*"
|
|
];
|
|
exclude = [
|
|
"resources/fonts/.*"
|
|
];
|
|
};
|
|
};
|
|
buildInputs = with pkgs; [ clojure nodejs bash git openjdk];
|
|
phases = [
|
|
"unpackPhase" "secretsPhase" "patchPhase"
|
|
"configurePhase" "buildPhase" "installPhase"
|
|
];
|
|
|
|
# For optional POKT_TOKEN variable
|
|
secretsPhase = if (secretsFile != "") then ''
|
|
source "${secretsFile}"
|
|
${lib.checkEnvVarSet "POKT_TOKEN"}
|
|
'' else ''
|
|
echo "No secrets provided!"
|
|
'';
|
|
|
|
# Patching shadow-cljs.edn so it uses the local maven repo of dependencies provided by Nix
|
|
patchPhase =
|
|
let anchor = ''{:source-paths ["src" "test/cljs"]'';
|
|
in ''
|
|
substituteInPlace shadow-cljs.edn \
|
|
--replace '${anchor}' \
|
|
'${anchor}
|
|
:maven {:local-repo "${deps.clojure}"}'
|
|
'';
|
|
configurePhase = ''
|
|
# Symlink Node.js modules to build directory
|
|
ln -s ${deps.nodejs}/node_modules
|
|
'';
|
|
buildPhase = ''
|
|
# Assemble CLASSPATH from available clojure dependencies.
|
|
# We append 'src' so it can find the local sources.
|
|
export CLASS_PATH="$(find ${deps.clojure} \
|
|
-iname '*.jar' | tr '\n' ':')src"
|
|
|
|
# target must be one of the builds defined in shadow-cljs.edn
|
|
java -cp "$CLASS_PATH" clojure.main \
|
|
-m shadow.cljs.devtools.cli release mobile
|
|
'';
|
|
installPhase = ''
|
|
mkdir -p $out
|
|
cp -r result/* $out/
|
|
'';
|
|
}
|