diff --git a/pkgs/tools/graphics/diagrams-builder/default.nix b/pkgs/tools/graphics/diagrams-builder/default.nix new file mode 100644 index 00000000000..a12e5dbb8bb --- /dev/null +++ b/pkgs/tools/graphics/diagrams-builder/default.nix @@ -0,0 +1,44 @@ +/* + If user need access to more haskell package for building his + diagrams, he simply has to pass these package through the + extra packages function as follow in `config.nix`: + + ~~~ + diagrams-builder.override { + extraPackages = self : [myHaskellPackage]; + } + ­~~~ +*/ + +{ stdenv, ghcWithPackages, makeWrapper, diagrams-builder, extraPackages ? (self: []) }: + +let + + # Used same technique as for the yiCustom package. + wrappedGhc = ghcWithPackages + (self: [ diagrams-builder ] ++ extraPackages self); + ghcVersion = wrappedGhc.version; + + exeWrapper = backend : '' + makeWrapper \ + "${diagrams-builder}/bin/diagrams-builder-${backend}" "$out/bin/diagrams-builder-${backend}" \ + --set NIX_GHC ${wrappedGhc}/bin/ghc \ + --set NIX_GHC_LIBDIR ${wrappedGhc}/lib/ghc-${ghcVersion} + ''; + + backends = ["svg" "cairo" "ps"]; + +in + +stdenv.mkDerivation { + name = "diagrams-builder"; + + buildInputs = [ makeWrapper ]; + + buildCommand = with stdenv.lib; + concatStrings (intersperse "\n" (map exeWrapper backends)); + + # Will be faster to build the wrapper locally then to fetch it from a binary cache. + preferLocalBuild = true; + meta = diagrams-builder.meta; +} \ No newline at end of file diff --git a/pkgs/top-level/all-packages.nix b/pkgs/top-level/all-packages.nix index 6bac3bfc57b..4206cc2cb92 100644 --- a/pkgs/top-level/all-packages.nix +++ b/pkgs/top-level/all-packages.nix @@ -786,6 +786,10 @@ let ddate = callPackage ../tools/misc/ddate { }; + diagrams-builder = callPackage ../tools/graphics/diagrams-builder { + inherit (haskellngPackages) ghcWithPackages diagrams-builder; + }; + direnv = callPackage ../tools/misc/direnv { }; discount = callPackage ../tools/text/discount { };