lfe: 1.2.1 -> 1.3
Add patches to the builder expression, and add those necessary for 1.3.
This commit is contained in:
parent
82e007f80f
commit
d723b91223
@ -66,8 +66,9 @@ let
|
||||
# Remove old versions of elixir, when the supports fades out:
|
||||
# https://hexdocs.pm/elixir/compatibility-and-deprecations.html
|
||||
|
||||
lfe = lfe_1_2;
|
||||
lfe = lfe_1_3;
|
||||
lfe_1_2 = lib.callLFE ../interpreters/lfe/1.2.nix { inherit erlang buildRebar3 buildHex; };
|
||||
lfe_1_3 = lib.callLFE ../interpreters/lfe/1.3.nix { inherit erlang buildRebar3 buildHex; };
|
||||
|
||||
# Non hex packages. Examples how to build Rebar/Mix packages with and
|
||||
# without helper functions buildRebar3 and buildMix.
|
||||
|
43
pkgs/development/interpreters/lfe/1.3.nix
Normal file
43
pkgs/development/interpreters/lfe/1.3.nix
Normal file
@ -0,0 +1,43 @@
|
||||
{ fetchpatch, mkDerivation }:
|
||||
|
||||
let
|
||||
_fetchpatch =
|
||||
{ rev, sha256 }:
|
||||
fetchpatch {
|
||||
url = "https://github.com/rvirding/lfe/commit/${rev}.patch";
|
||||
inherit sha256;
|
||||
};
|
||||
fetchPatches = map _fetchpatch;
|
||||
in
|
||||
|
||||
mkDerivation {
|
||||
version = "1.3";
|
||||
sha256 = "0pgwi0h0d34353m39jin8dxw4yykgfcg90k6pc4qkjyrg40hh4l6";
|
||||
maximumOTPVersion = "21";
|
||||
patches = fetchPatches [
|
||||
{
|
||||
rev = "b457e5d521bb35008e6049fab31b4073cc10d583";
|
||||
sha256 = "1zrq1b3291xhb0jsirgb5s8hacq5xvz7xidsp29aqcnpazdvivdc";
|
||||
}
|
||||
{
|
||||
rev = "5fe9f37741b7d53bd43109fd3435e1437f124a0d";
|
||||
sha256 = "1anqlcbih52lc0wynf58r67w1jhn264lz49rczwgh19pqg92dvqf";
|
||||
}
|
||||
{
|
||||
rev = "b8f3e06511cb6805cf3a904c1589b27f33f3958d";
|
||||
sha256 = "1zqafc0asm9m6cq7r0brvfawv69fqggy1phif3zknjmpicf25pqf";
|
||||
}
|
||||
{
|
||||
rev = "40c239a608460e55563edb68c1b6faca57518b54";
|
||||
sha256 = "03av5115jwyammw337xzy50l6api5h0wbwwda5vzw0w10zwb2z8y";
|
||||
}
|
||||
{
|
||||
rev = "5faa7106419263689bfc0bc08a7451ccb1fba718";
|
||||
sha256 = "0ml5yh5b3rn4ympks4bpx409hkra0i79zvq80azk0kmbjd869fxp";
|
||||
}
|
||||
{
|
||||
rev = "9ff978693babcfd043d741b5c6940920b8315892";
|
||||
sha256 = "04968dmp527wbkdv7dqpaj3nsyjls93whc1b5hx73b39dvl3n3y1";
|
||||
}
|
||||
];
|
||||
}
|
13
pkgs/development/interpreters/lfe/dedup-ebins.patch
Normal file
13
pkgs/development/interpreters/lfe/dedup-ebins.patch
Normal file
@ -0,0 +1,13 @@
|
||||
diff --git a/Makefile b/Makefile
|
||||
index 59f2c06..5ee8f6e 100644
|
||||
--- a/Makefile
|
||||
+++ b/Makefile
|
||||
@@ -60,7 +60,7 @@ ESRCS = $(notdir $(wildcard $(SRCDIR)/*.erl))
|
||||
XSRCS = $(notdir $(wildcard $(SRCDIR)/*.xrl))
|
||||
YSRCS = $(notdir $(wildcard $(SRCDIR)/*.yrl))
|
||||
LSRCS = $(notdir $(wildcard $(LSRCDIR)/*.lfe))
|
||||
-EBINS = $(ESRCS:.erl=.beam) $(XSRCS:.xrl=.beam) $(YSRCS:.yrl=.beam)
|
||||
+EBINS = $(sort $(ESRCS:.erl=.beam) $(XSRCS:.xrl=.beam) $(YSRCS:.yrl=.beam))
|
||||
LBINS = $(LSRCS:.lfe=.beam)
|
||||
|
||||
CSRCS = $(notdir $(wildcard $(CSRCDIR)/*.c))
|
@ -6,10 +6,13 @@
|
||||
, sha256 ? null
|
||||
, rev ? version
|
||||
, src ? fetchFromGitHub { inherit rev sha256; owner = "rvirding"; repo = "lfe"; }
|
||||
, patches ? []
|
||||
}:
|
||||
|
||||
let
|
||||
inherit (stdenv.lib) assertMsg getVersion versionAtLeast versions;
|
||||
inherit (stdenv.lib)
|
||||
assertMsg makeBinPath optionalString
|
||||
getVersion versionAtLeast versionOlder versions;
|
||||
|
||||
mainVersion = versions.major (getVersion erlang);
|
||||
|
||||
@ -36,13 +39,15 @@ buildRebar3 {
|
||||
|
||||
buildInputs = [ erlang makeWrapper ];
|
||||
beamDeps = [ proper ];
|
||||
patches = [ ./no-test-deps.patch ];
|
||||
patches = [ ./no-test-deps.patch ./dedup-ebins.patch ] ++ patches;
|
||||
doCheck = true;
|
||||
checkTarget = "travis";
|
||||
|
||||
makeFlags = [ "-e" "MANDB=''" "PREFIX=$$out"];
|
||||
|
||||
# These installPhase tricks are based on Elixir's Makefile.
|
||||
# TODO: Make, upload, and apply a patch.
|
||||
installPhase = ''
|
||||
installPhase = optionalString (versionOlder version "1.3") ''
|
||||
local libdir=$out/lib/lfe
|
||||
local ebindir=$libdir/ebin
|
||||
local bindir=$libdir/bin
|
||||
@ -65,7 +70,7 @@ buildRebar3 {
|
||||
# Add some stuff to PATH so the scripts can run without problems.
|
||||
for f in $out/bin/*; do
|
||||
wrapProgram $f \
|
||||
--prefix PATH ":" "${stdenv.lib.makeBinPath [ erlang coreutils bash ]}:$out/bin"
|
||||
--prefix PATH ":" "${makeBinPath [ erlang coreutils bash ]}:$out/bin"
|
||||
substituteInPlace $f --replace "/usr/bin/env" "${coreutils}/bin/env"
|
||||
done
|
||||
'';
|
||||
|
@ -9057,7 +9057,9 @@ in
|
||||
fetchHex beamPackages
|
||||
relxExe;
|
||||
|
||||
inherit (beam.packages.erlangR19) cuter lfe lfe_1_2;
|
||||
inherit (beam.packages.erlangR19) cuter lfe_1_2;
|
||||
|
||||
inherit (beam.packages.erlangR21) lfe lfe_1_3;
|
||||
|
||||
groovy = callPackage ../development/interpreters/groovy { };
|
||||
|
||||
|
@ -74,7 +74,7 @@ rec {
|
||||
# `beam.packages.erlangR22.elixir`.
|
||||
inherit (packages.erlang) elixir elixir_1_10 elixir_1_9 elixir_1_8 elixir_1_7 elixir_1_6;
|
||||
|
||||
inherit (packages.erlang) lfe lfe_1_2;
|
||||
inherit (packages.erlang) lfe lfe_1_2 lfe_1_3;
|
||||
};
|
||||
|
||||
# Helper function to generate package set with a specific Erlang version.
|
||||
|
Loading…
Reference in New Issue
Block a user