elixir-ls: build LS using the same Elixir version that is used to run LS
The Elixir LS package in Nixpkgs by default used the latest Elixir version available to compile and run Elixir LS. The user can build a custom Elixir LS package with a different Elixir version: my-custom-elixir-ls = pkgs.elixir-ls.override { elixir = my-custom-elixir; }; But by doing so the user changes only the Elixir version used to run Elixir LS; the Elixir version used to compile Elixir LS doesn't change. As the result, the custom Elixir LS package uses a different Elixir version at runtime than the Elixir version it was compiled with. In order to be able to modify the Elixir version used at build time, I changed `mixRelease` and `fetchMixDeps` to accept `elixir` and `hex` as parameters (defaults to the latest Elixir and Hex packages).
This commit is contained in:
parent
45891c5f1c
commit
2a9336b426
3 changed files with 8 additions and 3 deletions
|
@ -5,6 +5,7 @@
|
||||||
mixRelease rec {
|
mixRelease rec {
|
||||||
pname = "elixir-ls";
|
pname = "elixir-ls";
|
||||||
version = "0.8.1";
|
version = "0.8.1";
|
||||||
|
inherit elixir;
|
||||||
|
|
||||||
src = fetchFromGitHub {
|
src = fetchFromGitHub {
|
||||||
owner = "elixir-lsp";
|
owner = "elixir-lsp";
|
||||||
|
@ -16,7 +17,7 @@ mixRelease rec {
|
||||||
|
|
||||||
mixFodDeps = fetchMixDeps {
|
mixFodDeps = fetchMixDeps {
|
||||||
pname = "mix-deps-${pname}";
|
pname = "mix-deps-${pname}";
|
||||||
inherit src version;
|
inherit src version elixir;
|
||||||
sha256 = "sha256-OzjToAg+q/ybCyqzNFk28OBsItjFTbdPi416EPh2qX0=";
|
sha256 = "sha256-OzjToAg+q/ybCyqzNFk28OBsItjFTbdPi416EPh2qX0=";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
{ stdenvNoCC, lib, elixir, hex, rebar, rebar3, cacert, git }:
|
{ stdenvNoCC, lib, elixir, hex, rebar, rebar3, cacert, git }@inputs:
|
||||||
|
|
||||||
{ pname
|
{ pname
|
||||||
, version
|
, version
|
||||||
|
@ -8,6 +8,8 @@
|
||||||
, debug ? false
|
, debug ? false
|
||||||
, meta ? { }
|
, meta ? { }
|
||||||
, patches ? []
|
, patches ? []
|
||||||
|
, elixir ? inputs.elixir
|
||||||
|
, hex ? inputs.hex.override { inherit elixir; }
|
||||||
, ...
|
, ...
|
||||||
}@attrs:
|
}@attrs:
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
{ stdenv, lib, elixir, erlang, findutils, hex, rebar, rebar3, fetchMixDeps, makeWrapper, git, ripgrep }:
|
{ stdenv, lib, elixir, erlang, findutils, hex, rebar, rebar3, fetchMixDeps, makeWrapper, git, ripgrep }@inputs:
|
||||||
|
|
||||||
{ pname
|
{ pname
|
||||||
, version
|
, version
|
||||||
|
@ -15,6 +15,8 @@
|
||||||
# each dependency needs to have a setup hook to add the lib path to $ERL_LIBS
|
# each dependency needs to have a setup hook to add the lib path to $ERL_LIBS
|
||||||
# this is how mix will find dependencies
|
# this is how mix will find dependencies
|
||||||
, mixNixDeps ? { }
|
, mixNixDeps ? { }
|
||||||
|
, elixir ? inputs.elixir
|
||||||
|
, hex ? inputs.hex.override { inherit elixir; }
|
||||||
, ...
|
, ...
|
||||||
}@attrs:
|
}@attrs:
|
||||||
let
|
let
|
||||||
|
|
Loading…
Reference in a new issue