Skip to content

Commit

Permalink
chore(nix): updates to use nixpkgs elixir 1.17 (#525)
Browse files Browse the repository at this point in the history
* chore(nix): flake.lock: Update

Flake lock file updates:

• Updated input 'nixpkgs':
    'github:NixOS/nixpkgs/57d6973abba7ea108bac64ae7629e7431e0199b6' (2024-06-12)
  → 'github:NixOS/nixpkgs/a71e967ef3694799d0c418c98332f7ff4cc5f6af' (2024-06-22)

* chore(nix): use pkgs.elixir_1_17 and split package file
  • Loading branch information
adamcstephens authored Jul 3, 2024
1 parent 164d3b2 commit 7086c78
Show file tree
Hide file tree
Showing 4 changed files with 43 additions and 53 deletions.
6 changes: 3 additions & 3 deletions flake.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

52 changes: 3 additions & 49 deletions flake.nix
Original file line number Diff line number Diff line change
Expand Up @@ -18,28 +18,18 @@
}: let
inherit (nixpkgs) lib;

version = "0.23.0"; # x-release-please-version

# Helper to provide system-specific attributes
forAllSystems = f:
lib.genAttrs systems (system: let
pkgs = nixpkgs.legacyPackages.${system};
zpkgs = zigpkgs.legacyPackages.${system};
beamPackages = pkgs.beam_minimal.packages.erlang_27;
otp = (pkgs.beam.packagesWith beamPackages.erlang).extend (final: prev: {
elixir_1_17 = prev.elixir_1_16.override {
rev = "v1.17.0";
# You can discover this using Trust On First Use by filling in `lib.fakeHash`
sha256 = "sha256-RBylCfD+aCsvCqWUIvqXi3izNqqQoNfQNnQiZxz0Igg=";
version = "1.17.0";
};

beamPackages = pkgs.beam_minimal.packages.erlang_27.extend (final: prev: {
elixir = final.elixir_1_17;
# This will get upstreamed into nix-beam-flakes at some point
rebar = prev.rebar.overrideAttrs (_old: {doCheck = false;});
rebar3 = prev.rebar3.overrideAttrs (_old: {doCheck = false;});
});
elixir = otp.elixir;
elixir = beamPackages.elixir_1_17;
in
f {inherit system pkgs zpkgs beamPackages elixir;});

Expand All @@ -57,43 +47,7 @@
elixir,
...
}: {
default = lib.makeOverridable ({
localBuild,
beamPackages,
elixir,
}:
beamPackages.mixRelease {
pname = "next-ls";
src = self.outPath;
mixEnv = "prod";
removeCookie = false;
inherit version elixir;
inherit (beamPackages) erlang;

mixFodDeps = beamPackages.fetchMixDeps {
src = self.outPath;
inherit version elixir;
pname = "next-ls-deps";
hash = "sha256-4Rt5Q0fX+fbncvxyXdpIhgEvn9VYX/QDxDdnbanT21Q=";
mixEnv = "prod";
};

installPhase = ''
mix release --no-deps-check --path $out plain
echo "$out/bin/plain eval \"System.no_halt(true); Application.ensure_all_started(:next_ls)\" \"\$@\"" > "$out/bin/nextls"
chmod +x "$out/bin/nextls"
'';

meta = with lib; {
license = licenses.mit;
homepage = "https://www.elixir-tools.dev/next-ls/";
description = "The language server for Elixir that just works";
mainProgram = "nextls";
};
}) {
inherit beamPackages elixir;
localBuild = true;
};
default = pkgs.callPackage ./package.nix { inherit beamPackages elixir; };
});

devShells = forAllSystems ({
Expand Down
36 changes: 36 additions & 0 deletions package.nix
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
{
lib,
beamPackages,
elixir,
}:

beamPackages.mixRelease rec {
pname = "next-ls";
src = ./.;
mixEnv = "prod";
removeCookie = false;
version = "0.23.0"; # x-release-please-version

inherit elixir;
inherit (beamPackages) erlang;

mixFodDeps = beamPackages.fetchMixDeps {
inherit src version elixir;
pname = "next-ls-deps";
hash = "sha256-4Rt5Q0fX+fbncvxyXdpIhgEvn9VYX/QDxDdnbanT21Q=";
mixEnv = "prod";
};

installPhase = ''
mix release --no-deps-check --path $out plain
echo "$out/bin/plain eval \"System.no_halt(true); Application.ensure_all_started(:next_ls)\" \"\$@\"" > "$out/bin/nextls"
chmod +x "$out/bin/nextls"
'';

meta = with lib; {
license = licenses.mit;
homepage = "https://www.elixir-tools.dev/next-ls/";
description = "The language server for Elixir that just works";
mainProgram = "nextls";
};
}
2 changes: 1 addition & 1 deletion release-please-config.json
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
"include-component-in-tag": false,
"draft": true,
"extra-files": [
"flake.nix"
"package.nix"
]
}
}
Expand Down

0 comments on commit 7086c78

Please sign in to comment.