nixfmt
This commit is contained in:
parent
7796082dbc
commit
1c2ff72eb1
|
@ -14,9 +14,7 @@ let
|
||||||
|
|
||||||
contents = [ pkg ];
|
contents = [ pkg ];
|
||||||
|
|
||||||
config = {
|
config = { Cmd = [ "/bin/${pkg.name}" ]; };
|
||||||
Cmd = [ "/bin/${pkg.name}" ];
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
|
|
||||||
in dockerImage minica
|
in dockerImage minica
|
||||||
|
|
|
@ -14,9 +14,7 @@ let
|
||||||
|
|
||||||
contents = [ pkg ];
|
contents = [ pkg ];
|
||||||
|
|
||||||
config = {
|
config = { Cmd = [ "/bin/${pkg.name}" ]; };
|
||||||
Cmd = [ "/bin/${pkg.name}" ];
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
|
|
||||||
in dockerImage moonplus
|
in dockerImage moonplus
|
||||||
|
|
135
nix/sources.nix
135
nix/sources.nix
|
@ -19,29 +19,28 @@ let
|
||||||
pkgs.fetchzip { inherit (spec) url sha256; };
|
pkgs.fetchzip { inherit (spec) url sha256; };
|
||||||
|
|
||||||
fetch_git = spec:
|
fetch_git = spec:
|
||||||
builtins.fetchGit { url = spec.repo; inherit (spec) rev ref; };
|
builtins.fetchGit {
|
||||||
|
url = spec.repo;
|
||||||
|
inherit (spec) rev ref;
|
||||||
|
};
|
||||||
|
|
||||||
fetch_builtin-tarball = spec:
|
fetch_builtin-tarball = spec:
|
||||||
builtins.trace
|
builtins.trace ''
|
||||||
''
|
WARNING:
|
||||||
WARNING:
|
The niv type "builtin-tarball" will soon be deprecated. You should
|
||||||
The niv type "builtin-tarball" will soon be deprecated. You should
|
instead use `builtin = true`.
|
||||||
instead use `builtin = true`.
|
|
||||||
|
|
||||||
$ niv modify <package> -a type=tarball -a builtin=true
|
$ niv modify <package> -a type=tarball -a builtin=true
|
||||||
''
|
'' builtins_fetchTarball { inherit (spec) url sha256; };
|
||||||
builtins_fetchTarball { inherit (spec) url sha256; };
|
|
||||||
|
|
||||||
fetch_builtin-url = spec:
|
fetch_builtin-url = spec:
|
||||||
builtins.trace
|
builtins.trace ''
|
||||||
''
|
WARNING:
|
||||||
WARNING:
|
The niv type "builtin-url" will soon be deprecated. You should
|
||||||
The niv type "builtin-url" will soon be deprecated. You should
|
instead use `builtin = true`.
|
||||||
instead use `builtin = true`.
|
|
||||||
|
|
||||||
$ niv modify <package> -a type=file -a builtin=true
|
$ niv modify <package> -a type=file -a builtin=true
|
||||||
''
|
'' (builtins_fetchurl { inherit (spec) url sha256; });
|
||||||
(builtins_fetchurl { inherit (spec) url sha256; });
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# Various helpers
|
# Various helpers
|
||||||
|
@ -51,84 +50,84 @@ let
|
||||||
mkPkgs = sources:
|
mkPkgs = sources:
|
||||||
let
|
let
|
||||||
sourcesNixpkgs =
|
sourcesNixpkgs =
|
||||||
import (builtins_fetchTarball { inherit (sources.nixpkgs) url sha256; }) {};
|
import (builtins_fetchTarball { inherit (sources.nixpkgs) url sha256; })
|
||||||
|
{ };
|
||||||
hasNixpkgsPath = builtins.any (x: x.prefix == "nixpkgs") builtins.nixPath;
|
hasNixpkgsPath = builtins.any (x: x.prefix == "nixpkgs") builtins.nixPath;
|
||||||
hasThisAsNixpkgsPath = <nixpkgs> == ./.;
|
hasThisAsNixpkgsPath = <nixpkgs> == ./.;
|
||||||
in
|
in if builtins.hasAttr "nixpkgs" sources then
|
||||||
if builtins.hasAttr "nixpkgs" sources
|
sourcesNixpkgs
|
||||||
then sourcesNixpkgs
|
else if hasNixpkgsPath && !hasThisAsNixpkgsPath then
|
||||||
else if hasNixpkgsPath && ! hasThisAsNixpkgsPath then
|
import <nixpkgs> { }
|
||||||
import <nixpkgs> {}
|
else
|
||||||
else
|
abort ''
|
||||||
abort
|
Please specify either <nixpkgs> (through -I or NIX_PATH=nixpkgs=...) or
|
||||||
''
|
add a package called "nixpkgs" to your sources.json.
|
||||||
Please specify either <nixpkgs> (through -I or NIX_PATH=nixpkgs=...) or
|
'';
|
||||||
add a package called "nixpkgs" to your sources.json.
|
|
||||||
'';
|
|
||||||
|
|
||||||
# The actual fetching function.
|
# The actual fetching function.
|
||||||
fetch = pkgs: name: spec:
|
fetch = pkgs: name: spec:
|
||||||
|
|
||||||
if ! builtins.hasAttr "type" spec then
|
if !builtins.hasAttr "type" spec then
|
||||||
abort "ERROR: niv spec ${name} does not have a 'type' attribute"
|
abort "ERROR: niv spec ${name} does not have a 'type' attribute"
|
||||||
else if spec.type == "file" then fetch_file pkgs spec
|
else if spec.type == "file" then
|
||||||
else if spec.type == "tarball" then fetch_tarball pkgs spec
|
fetch_file pkgs spec
|
||||||
else if spec.type == "git" then fetch_git spec
|
else if spec.type == "tarball" then
|
||||||
else if spec.type == "builtin-tarball" then fetch_builtin-tarball spec
|
fetch_tarball pkgs spec
|
||||||
else if spec.type == "builtin-url" then fetch_builtin-url spec
|
else if spec.type == "git" then
|
||||||
|
fetch_git spec
|
||||||
|
else if spec.type == "builtin-tarball" then
|
||||||
|
fetch_builtin-tarball spec
|
||||||
|
else if spec.type == "builtin-url" then
|
||||||
|
fetch_builtin-url spec
|
||||||
else
|
else
|
||||||
abort "ERROR: niv spec ${name} has unknown type ${builtins.toJSON spec.type}";
|
abort
|
||||||
|
"ERROR: niv spec ${name} has unknown type ${builtins.toJSON spec.type}";
|
||||||
|
|
||||||
# Ports of functions for older nix versions
|
# Ports of functions for older nix versions
|
||||||
|
|
||||||
# a Nix version of mapAttrs if the built-in doesn't exist
|
# a Nix version of mapAttrs if the built-in doesn't exist
|
||||||
mapAttrs = builtins.mapAttrs or (
|
mapAttrs = builtins.mapAttrs or (f: set:
|
||||||
f: set: with builtins;
|
with builtins;
|
||||||
listToAttrs (map (attr: { name = attr; value = f attr set.${attr}; }) (attrNames set))
|
listToAttrs (map (attr: {
|
||||||
);
|
name = attr;
|
||||||
|
value = f attr set.${attr};
|
||||||
|
}) (attrNames set)));
|
||||||
|
|
||||||
# fetchTarball version that is compatible between all the versions of Nix
|
# fetchTarball version that is compatible between all the versions of Nix
|
||||||
builtins_fetchTarball = { url, sha256 }@attrs:
|
builtins_fetchTarball = { url, sha256 }@attrs:
|
||||||
let
|
let inherit (builtins) lessThan nixVersion fetchTarball;
|
||||||
inherit (builtins) lessThan nixVersion fetchTarball;
|
in if lessThan nixVersion "1.12" then
|
||||||
in
|
fetchTarball { inherit url; }
|
||||||
if lessThan nixVersion "1.12" then
|
else
|
||||||
fetchTarball { inherit url; }
|
fetchTarball attrs;
|
||||||
else
|
|
||||||
fetchTarball attrs;
|
|
||||||
|
|
||||||
# fetchurl version that is compatible between all the versions of Nix
|
# fetchurl version that is compatible between all the versions of Nix
|
||||||
builtins_fetchurl = { url, sha256 }@attrs:
|
builtins_fetchurl = { url, sha256 }@attrs:
|
||||||
let
|
let inherit (builtins) lessThan nixVersion fetchurl;
|
||||||
inherit (builtins) lessThan nixVersion fetchurl;
|
in if lessThan nixVersion "1.12" then
|
||||||
in
|
fetchurl { inherit url; }
|
||||||
if lessThan nixVersion "1.12" then
|
else
|
||||||
fetchurl { inherit url; }
|
fetchurl attrs;
|
||||||
else
|
|
||||||
fetchurl attrs;
|
|
||||||
|
|
||||||
# Create the final "sources" from the config
|
# Create the final "sources" from the config
|
||||||
mkSources = config:
|
mkSources = config:
|
||||||
mapAttrs (
|
mapAttrs (name: spec:
|
||||||
name: spec:
|
if builtins.hasAttr "outPath" spec then
|
||||||
if builtins.hasAttr "outPath" spec
|
abort
|
||||||
then abort
|
"The values in sources.json should not have an 'outPath' attribute"
|
||||||
"The values in sources.json should not have an 'outPath' attribute"
|
else
|
||||||
else
|
spec // { outPath = fetch config.pkgs name spec; }) config.sources;
|
||||||
spec // { outPath = fetch config.pkgs name spec; }
|
|
||||||
) config.sources;
|
|
||||||
|
|
||||||
# The "config" used by the fetchers
|
# The "config" used by the fetchers
|
||||||
mkConfig =
|
mkConfig = { sourcesFile ? ./sources.json
|
||||||
{ sourcesFile ? ./sources.json
|
|
||||||
, sources ? builtins.fromJSON (builtins.readFile sourcesFile)
|
, sources ? builtins.fromJSON (builtins.readFile sourcesFile)
|
||||||
, pkgs ? mkPkgs sources
|
, pkgs ? mkPkgs sources }: rec {
|
||||||
}: rec {
|
|
||||||
# The sources, i.e. the attribute set of spec name to spec
|
# The sources, i.e. the attribute set of spec name to spec
|
||||||
inherit sources;
|
inherit sources;
|
||||||
|
|
||||||
# The "pkgs" (evaluated nixpkgs) to use for e.g. non-builtin fetchers
|
# The "pkgs" (evaluated nixpkgs) to use for e.g. non-builtin fetchers
|
||||||
inherit pkgs;
|
inherit pkgs;
|
||||||
};
|
};
|
||||||
in
|
in mkSources (mkConfig { }) // {
|
||||||
mkSources (mkConfig {}) // { __functor = _: settings: mkSources (mkConfig settings); }
|
__functor = _: settings: mkSources (mkConfig settings);
|
||||||
|
}
|
||||||
|
|
|
@ -1,9 +1,9 @@
|
||||||
{ sources ? import ../../nix/sources.nix, pkgs ? import <nixpkgs> {} }:
|
{ sources ? import ../../nix/sources.nix, pkgs ? import <nixpkgs> { } }:
|
||||||
with pkgs;
|
with pkgs;
|
||||||
let
|
let
|
||||||
defaultAttrs = {
|
defaultAttrs = {
|
||||||
builder = ./builder.sh;
|
builder = ./builder.sh;
|
||||||
baseInputs = [];
|
baseInputs = [ ];
|
||||||
src = sources.MoonPlus;
|
src = sources.MoonPlus;
|
||||||
version = "HEAD";
|
version = "HEAD";
|
||||||
name = "MoonPlus";
|
name = "MoonPlus";
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
dir:
|
dir:
|
||||||
builtins.filterSource
|
builtins.filterSource
|
||||||
(path: type: type != "directory" || builtins.baseNameOf path != "target")
|
(path: type: type != "directory" || builtins.baseNameOf path != "target") dir
|
||||||
dir
|
|
||||||
|
|
|
@ -14,17 +14,17 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
modSha256 = "sha256-mTzZcEoag1/1IAZCSY7MLgNS+lI453GM8SM1aFVLKUU=";
|
modSha256 = "sha256-mTzZcEoag1/1IAZCSY7MLgNS+lI453GM8SM1aFVLKUU=";
|
||||||
CGO_ENABLED="0";
|
CGO_ENABLED = "0";
|
||||||
|
|
||||||
allowGoReference = true;
|
allowGoReference = true;
|
||||||
|
|
||||||
subPackages = [
|
subPackages = [
|
||||||
"cmd/appsluggr"
|
"cmd/appsluggr"
|
||||||
"cmd/johaus"
|
"cmd/johaus"
|
||||||
"cmd/license"
|
"cmd/license"
|
||||||
"cmd/mainsanow"
|
"cmd/mainsanow"
|
||||||
"cmd/prefix"
|
"cmd/prefix"
|
||||||
"cmd/quickserv"
|
"cmd/quickserv"
|
||||||
];
|
];
|
||||||
|
|
||||||
outputs = [
|
outputs = [
|
||||||
|
@ -50,8 +50,7 @@ let
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
in
|
in {
|
||||||
{
|
|
||||||
appsluggr = out.appsluggr;
|
appsluggr = out.appsluggr;
|
||||||
quickserv = out.quickserv;
|
quickserv = out.quickserv;
|
||||||
johaus = out.johaus;
|
johaus = out.johaus;
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
{pkgs ? import <nixpkgs> {}}:
|
{ pkgs ? import <nixpkgs> { } }:
|
||||||
|
|
||||||
version: shasums:
|
version: shasums:
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue