forked from extern/flakelight
Allow devShell to be set to a package definition
This commit is contained in:
parent
b094ced95d
commit
8f3bfc39aa
@ -371,6 +371,9 @@ such an attribute set in order to access packages.
|
||||
`devShell.stdenv` allows changing the stdenv used for the shell. It is a
|
||||
function that takes the package set and returns the stdenv to use.
|
||||
|
||||
`devShell` can alternatively be set to a package definition, which is then used
|
||||
as the default shell, overriding the above options.
|
||||
|
||||
For example, these can be configured as follows:
|
||||
|
||||
```nix
|
||||
@ -397,7 +400,7 @@ For example, these can be configured as follows:
|
||||
|
||||
The above exports `devShells.${system}.default` outputs.
|
||||
|
||||
To add build inputs of one of your packages, you can do as follows:
|
||||
To add the build inputs of one of your packages, you can do as follows:
|
||||
|
||||
```nix
|
||||
{
|
||||
|
@ -5,17 +5,12 @@
|
||||
{ config, lib, flakelight, ... }:
|
||||
let
|
||||
inherit (lib) filterAttrs mapAttrs mkDefault mkIf mkMerge mkOption;
|
||||
inherit (lib.types) functionTo lazyAttrsOf lines listOf nullOr package str
|
||||
submodule;
|
||||
inherit (lib.types) coercedTo functionTo lazyAttrsOf lines listOf nullOr
|
||||
package str submodule;
|
||||
inherit (flakelight) supportedSystem;
|
||||
inherit (flakelight.types) optFunctionTo packageDef;
|
||||
in
|
||||
{
|
||||
options = {
|
||||
devShell = mkOption {
|
||||
default = null;
|
||||
type = nullOr (submodule {
|
||||
options = {
|
||||
|
||||
devShellModule.options = {
|
||||
inputsFrom = mkOption {
|
||||
type = functionTo (listOf package);
|
||||
default = _: [ ];
|
||||
@ -40,8 +35,21 @@ in
|
||||
type = functionTo package;
|
||||
default = pkgs: pkgs.stdenv;
|
||||
};
|
||||
|
||||
overrideShell = mkOption {
|
||||
type = nullOr packageDef;
|
||||
internal = true;
|
||||
default = null;
|
||||
};
|
||||
});
|
||||
};
|
||||
in
|
||||
{
|
||||
options = {
|
||||
devShell = mkOption {
|
||||
default = null;
|
||||
type = nullOr (coercedTo packageDef
|
||||
(x: { overrideShell = x; })
|
||||
(submodule devShellModule));
|
||||
};
|
||||
|
||||
devShells = mkOption {
|
||||
@ -53,12 +61,13 @@ in
|
||||
config = mkMerge [
|
||||
(mkIf (config.devShell != null) {
|
||||
devShells.default = mkDefault ({ pkgs, mkShell }:
|
||||
mkShell.override { stdenv = config.devShell.stdenv pkgs; }
|
||||
((config.devShell.env pkgs) // {
|
||||
inputsFrom = config.devShell.inputsFrom pkgs;
|
||||
packages = config.devShell.packages pkgs;
|
||||
shellHook = config.devShell.shellHook pkgs;
|
||||
}));
|
||||
let cfg = mapAttrs (_: v: v pkgs) config.devShell; in
|
||||
mkShell.override { inherit (cfg) stdenv; }
|
||||
(cfg.env // { inherit (cfg) inputsFrom packages shellHook; }));
|
||||
})
|
||||
|
||||
(mkIf (config.devShell.overrideShell or null != null) {
|
||||
devShells.default = config.devShell.overrideShell;
|
||||
})
|
||||
|
||||
(mkIf (config.devShells != { }) {
|
||||
|
@ -298,7 +298,7 @@ in
|
||||
|
||||
devShell-override = test
|
||||
(flakelight ./empty {
|
||||
devShells.default = { mkShell }: mkShell { };
|
||||
devShell = { mkShell }: mkShell { };
|
||||
})
|
||||
(f: f ? devShells.x86_64-linux.default);
|
||||
|
||||
@ -314,6 +314,12 @@ in
|
||||
&& (f ? devShells.x86_64-linux.shell1)
|
||||
&& (f ? devShells.x86_64-linux.shell2));
|
||||
|
||||
devShells-override = test
|
||||
(flakelight ./empty {
|
||||
devShells.default = { mkShell }: mkShell { };
|
||||
})
|
||||
(f: f ? devShells.x86_64-linux.default);
|
||||
|
||||
overlay = test
|
||||
(flakelight ./empty {
|
||||
overlay = final: prev: { testValue = "hello"; };
|
||||
|
Loading…
Reference in New Issue
Block a user