nixpkgs-suyu/pkgs/development/r-modules
Matthew Justin Bauer 24e38f3075
r-modules: fix eval
Fixes #31508
2017-11-12 21:49:41 -06:00
..
patches
bioc-annotation-packages.nix R: update package set 2017-08-31 21:59:06 +02:00
bioc-experiment-packages.nix R: update package set 2017-08-31 21:59:06 +02:00
bioc-packages.nix R: update package set 2017-08-31 21:59:06 +02:00
cran-packages.nix R: update package set 2017-09-29 15:21:09 +02:00
default.nix r-modules: fix eval 2017-11-12 21:49:41 -06:00
generate-r-packages.R
generate-shell.nix R: update list of broken packages (and some cosmetic) 2017-04-24 15:39:54 +02:00
generic-builder.nix
README.md nixpkgs manual: add rstudio shell.nix example 2017-11-04 12:26:08 +01:00
test-evaluation.nix
wrapper-rstudio.nix rstudio: Fix recompilation issue with custom package set 2017-05-01 09:46:40 -04:00
wrapper.nix rstudio: Fix recompilation issue with custom package set 2017-05-01 09:46:40 -04:00

R packages

Installation

Define an environment for R that contains all the libraries that you'd like to use by adding the following snippet to your $HOME/.config/nixpkgs/config.nix file:

{
    packageOverrides = super: let self = super.pkgs; in
    {

        rEnv = super.rWrapper.override {
            packages = with self.rPackages; [
                devtools
                ggplot2
                reshape2
                yaml
                optparse
                ];
        };
    };
}

Then you can use nix-env -f "<nixpkgs>" -iA rEnv to install it into your user profile. The set of available libraries can be discovered by running the command nix-env -f "<nixpkgs>" -qaP -A rPackages. The first column from that output is the name that has to be passed to rWrapper in the code snipped above.

However, if you'd like to add a file to your project source to make the environment available for other contributors, you can create a default.nix file like so:

let
  pkgs = import <nixpkgs> {};
  stdenv = pkgs.stdenv;
in with pkgs; {
  myProject = stdenv.mkDerivation {
    name = "myProject";
    version = "1";
    src = if pkgs.lib.inNixShell then null else nix;

    buildInputs = with rPackages; [
      R
      ggplot2
      knitr
    ];
  };
}

and then run nix-shell . to be dropped into a shell with those packages available.

RStudio

RStudio uses a standard set of packages and ignores any custom R environments or installed packages you may have. To create a custom environment, see rstudioWrapper, which functions similarly to rWrapper:

{
    packageOverrides = super: let self = super.pkgs; in
    {

        rstudioEnv = super.rstudioWrapper.override {
            packages = with self.rPackages; [
                dplyr
                ggplot2
                reshape2
                ];
        };
    };
}

Then like above, nix-env -f "<nixpkgs>" -iA rstudioEnv will install this into your user profile.

Alternatively, you can create a self-contained shell.nix without the need to modify any configuration files:

{ pkgs ? import <nixpkgs> {}
}:

pkgs.rstudioWrapper.override {
  packages = with pkgs.rPackages; [ dplyr ggplot2 reshape2 ];
}

Executing nix-shell will then drop you into an environment equivalent to the one above. If you need additional packages just add them to the list and re-enter the shell.

Updating the package set

nix-shell generate-shell.nix

Rscript generate-r-packages.R cran  > cran-packages.nix.new
mv cran-packages.nix.new cran-packages.nix

Rscript generate-r-packages.R bioc  > bioc-packages.nix.new
mv bioc-packages.nix.new bioc-packages.nix

generate-r-packages.R <repo> reads <repo>-packages.nix, therefor the renaming.

Testing if the Nix-expression could be evaluated

nix-build test-evaluation.nix --dry-run

If this exits fine, the expression is ok. If not, you have to edit default.nix