diff options
author | makefu <github@syntax-fehler.de> | 2015-10-14 00:17:15 +0200 |
---|---|---|
committer | makefu <github@syntax-fehler.de> | 2015-10-14 00:17:15 +0200 |
commit | df3dc3dac1f6c1cc36dbbea506e3d610aa1b417d (patch) | |
tree | 038a837b20d267d0ba5aad837884b6a5a9087613 /lass/5pkgs/go/default.nix | |
parent | f73fe104d84b2f0d2fc3b4f0342c36735b3fb220 (diff) | |
parent | 96f4248b65ff1539eded24572ae1805b27c53d50 (diff) |
Merge remote-tracking branch 'cd/master'
Diffstat (limited to 'lass/5pkgs/go/default.nix')
-rw-r--r-- | lass/5pkgs/go/default.nix | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/lass/5pkgs/go/default.nix b/lass/5pkgs/go/default.nix new file mode 100644 index 000000000..3b4468d18 --- /dev/null +++ b/lass/5pkgs/go/default.nix @@ -0,0 +1,59 @@ +{ stdenv, makeWrapper, lib, buildEnv, fetchgit, nodePackages, nodejs }: + +with lib; + +let + np = nodePackages.override { + generated = ./packages.nix; + self = np; + }; + + node_env = buildEnv { + name = "node_env"; + paths = [ + np.redis + np."formidable" + ]; + pathsToLink = [ "/lib" ]; + ignoreCollisions = true; + }; + +in nodePackages.buildNodePackage { + name = "go"; + + src = fetchgit { + url = "http://cgit.echelon/go/"; + rev = "05d02740e0adbb36cc461323647f0c1e7f493156"; + sha256 = "6015c9a93317375ae8099c7ab982df0aa93a59ec2b48972e253887bb6ca0004f"; + }; + + phases = [ + "unpackPhase" + "installPhase" + ]; + + deps = (filter (v: nixType v == "derivation") (attrValues np)); + + buildInputs = [ + nodejs + nodePackages.redis + np.formidable + makeWrapper + ]; + + installPhase = '' + mkdir -p $out/bin + + cp index.js $out/ + cat > $out/go << EOF + ${nodejs}/bin/node $out/index.js + EOF + chmod +x $out/go + + wrapProgram $out/go \ + --prefix NODE_PATH : ${node_env}/lib/node_modules + + ln -s $out/go /$out/bin/go + ''; + +} |