aboutsummaryrefslogtreecommitdiff
path: root/infra/libkookie/nixpkgs/pkgs/development/r-modules/generic-builder.nix
diff options
context:
space:
mode:
authorMx Kookie <kookie@spacekookie.de>2020-10-31 19:35:09 +0100
committerMx Kookie <kookie@spacekookie.de>2020-10-31 19:35:09 +0100
commitc4625b175f8200f643fd6e11010932ea44c78433 (patch)
treebce3f89888c8ac3991fa5569a878a9eab6801ccc /infra/libkookie/nixpkgs/pkgs/development/r-modules/generic-builder.nix
parent49f735974dd103039ddc4cb576bb76555164a9e7 (diff)
parentd661aa56a8843e991261510c1bb28fdc2f6975ae (diff)
Add 'infra/libkookie/' from commit 'd661aa56a8843e991261510c1bb28fdc2f6975ae'
git-subtree-dir: infra/libkookie git-subtree-mainline: 49f735974dd103039ddc4cb576bb76555164a9e7 git-subtree-split: d661aa56a8843e991261510c1bb28fdc2f6975ae
Diffstat (limited to 'infra/libkookie/nixpkgs/pkgs/development/r-modules/generic-builder.nix')
-rw-r--r--infra/libkookie/nixpkgs/pkgs/development/r-modules/generic-builder.nix54
1 files changed, 54 insertions, 0 deletions
diff --git a/infra/libkookie/nixpkgs/pkgs/development/r-modules/generic-builder.nix b/infra/libkookie/nixpkgs/pkgs/development/r-modules/generic-builder.nix
new file mode 100644
index 000000000000..76bf29abc17c
--- /dev/null
+++ b/infra/libkookie/nixpkgs/pkgs/development/r-modules/generic-builder.nix
@@ -0,0 +1,54 @@
+{ stdenv, R, libcxx, xvfb_run, utillinux, Cocoa, Foundation, gettext, gfortran }:
+
+{ name, buildInputs ? [], requireX ? false, ... } @ attrs:
+
+stdenv.mkDerivation ({
+ buildInputs = buildInputs ++ [R gettext] ++
+ stdenv.lib.optionals requireX [utillinux xvfb_run] ++
+ stdenv.lib.optionals stdenv.isDarwin [Cocoa Foundation gfortran];
+
+ NIX_CFLAGS_COMPILE =
+ stdenv.lib.optionalString stdenv.isDarwin "-I${libcxx}/include/c++/v1";
+
+ configurePhase = ''
+ runHook preConfigure
+ export R_LIBS_SITE="$R_LIBS_SITE''${R_LIBS_SITE:+:}$out/library"
+ runHook postConfigure
+ '';
+
+ buildPhase = ''
+ runHook preBuild
+ runHook postBuild
+ '';
+
+ installFlags = if attrs.doCheck or true then
+ []
+ else
+ [ "--no-test-load" ];
+
+ rCommand = if requireX then
+ # Unfortunately, xvfb-run has a race condition even with -a option, so that
+ # we acquire a lock explicitly.
+ "flock ${xvfb_run} xvfb-run -a -e xvfb-error R"
+ else
+ "R";
+
+ installPhase = ''
+ runHook preInstall
+ mkdir -p $out/library
+ $rCommand CMD INSTALL $installFlags --configure-args="$configureFlags" -l $out/library .
+ runHook postInstall
+ '';
+
+ postFixup = ''
+ if test -e $out/nix-support/propagated-build-inputs; then
+ ln -s $out/nix-support/propagated-build-inputs $out/nix-support/propagated-user-env-packages
+ fi
+ '';
+
+ checkPhase = ''
+ # noop since R CMD INSTALL tests packages
+ '';
+} // attrs // {
+ name = "r-" + name;
+})